Reorganizes project and sets up bazel.
This commit is contained in:
		
							
								
								
									
										751
									
								
								list.h
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										751
									
								
								list.h
									
									
									
									
									
										Executable file
									
								
							| @@ -0,0 +1,751 @@ | ||||
| /*************************************************************************** | ||||
|  *   Copyright (C) 2001-2023 by Tom Hicks                                  * | ||||
|  *   headhunter3@gmail.com                                                 * | ||||
|  *                                                                         * | ||||
|  *   This program is free software; you can redistribute it and/or modify  * | ||||
|  *   it under the terms of the GNU General Public License as published by  * | ||||
|  *   the Free Software Foundation; either version 2 of the License, or     * | ||||
|  *   (at your option) any later version.                                   * | ||||
|  *                                                                         * | ||||
|  *   This program is distributed in the hope that it will be useful,       * | ||||
|  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        * | ||||
|  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * | ||||
|  *   GNU General Public License for more details.                          * | ||||
|  *                                                                         * | ||||
|  *   You should have received a copy of the GNU General Public License     * | ||||
|  *   along with this program; if not, write to the                         * | ||||
|  *   Free Software Foundation, Inc.,                                       * | ||||
|  *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             * | ||||
|  ***************************************************************************/ | ||||
| #ifndef OpenArena__list_h__ | ||||
| #define OpenArena__list_h__ | ||||
|  | ||||
| #if defined HAVE_CONFIG_H | ||||
| #include "config.h" | ||||
| #endif | ||||
|  | ||||
| #include <cstdlib> | ||||
|  | ||||
| #pragma clang diagnostic push | ||||
| #pragma clang diagnostic ignored "-Wunknown-pragmas" | ||||
| #pragma warning(disable : 4715) | ||||
|  | ||||
| namespace OpenArena { | ||||
| typedef unsigned int LIST_ARRAY_INDEX_TYPE; | ||||
|  | ||||
| /*! | ||||
|  * \brief | ||||
|  * Write brief comment for listNode here. | ||||
|  * | ||||
|  * \param ItemType | ||||
|  * Description of parameter ItemType. | ||||
|  * | ||||
|  * Write detailed description for listNode here. | ||||
|  * | ||||
|  * \remarks | ||||
|  * Write remarks for listNode here. | ||||
|  * | ||||
|  * \see | ||||
|  * Separate items with the '|' character. | ||||
|  */ | ||||
| template <class ItemType> | ||||
| class listNode { | ||||
|  public: | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for listNode here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for listNode here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for listNode here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   listNode(); | ||||
|   ItemType data; | ||||
|   listNode<ItemType>* next; | ||||
| }; | ||||
|  | ||||
| /*! | ||||
|  * \brief | ||||
|  * Write brief comment for list here. | ||||
|  * | ||||
|  * \param ItemType | ||||
|  * Description of parameter ItemType. | ||||
|  * | ||||
|  * Write detailed description for list here. | ||||
|  * | ||||
|  * \remarks | ||||
|  * Write remarks for list here. | ||||
|  * | ||||
|  * \see | ||||
|  * Separate items with the '|' character. | ||||
|  */ | ||||
| template <class ItemType> | ||||
| class list { | ||||
|  public: | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for list here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for list here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for list here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   list(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for ~list here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for ~list here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for ~list here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   ~list(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for list here. | ||||
|    * | ||||
|    * \param | ||||
|    * Description of parameter . | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for list here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for list here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   list(const list&); | ||||
|  | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for IsEmpty here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for IsEmpty here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for IsEmpty here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool IsEmpty() const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for IsFull here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for IsFull here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for IsFull here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool IsFull() const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Insert here. | ||||
|    * | ||||
|    * \param newItem | ||||
|    * Description of parameter newItem. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Insert here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Insert here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void Insert(ItemType newItem); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Remove here. | ||||
|    * | ||||
|    * \param target | ||||
|    * Description of parameter target. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Remove here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Remove here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void Remove(ItemType target); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Remove here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Remove here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Remove here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void Remove(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Retrieve here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Retrieve here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Retrieve here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   ItemType Retrieve() const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for PrevPosition here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for PrevPosition here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for PrevPosition here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool PrevPosition(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for NextPosition here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for NextPosition here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for NextPosition here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool NextPosition(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for IsFirstPosition here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for IsFirstPosition here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for IsFirstPosition here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool IsFirstPosition() const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for IsLastPosition here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for IsLastPosition here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for IsLastPosition here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool IsLastPosition() const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for FirstPosition here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for FirstPosition here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for FirstPosition here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void FirstPosition(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for LastPosition here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for LastPosition here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for LastPosition here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void LastPosition(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Clear here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Clear here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Clear here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void Clear(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Contains here. | ||||
|    * | ||||
|    * \param | ||||
|    * Description of parameter . | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Contains here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Contains here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   bool Contains(ItemType) const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for Length here. | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for Length here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for Length here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   unsigned int Length(); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for operator = here. | ||||
|    * | ||||
|    * \param | ||||
|    * Description of parameter . | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for operator = here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for operator = here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   void operator=(const list<ItemType>&); | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for operator [] here. | ||||
|    * | ||||
|    * \param | ||||
|    * Description of parameter . | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for operator [] here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for operator [] here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   ItemType operator[](LIST_ARRAY_INDEX_TYPE) const; | ||||
|   /*! | ||||
|    * \brief | ||||
|    * Write brief comment for operator [] here. | ||||
|    * | ||||
|    * \param | ||||
|    * Description of parameter . | ||||
|    * | ||||
|    * \returns | ||||
|    * Write description of return value here. | ||||
|    * | ||||
|    * \throws <exception class> | ||||
|    * Description of criteria for throwing this exception. | ||||
|    * | ||||
|    * Write detailed description for operator [] here. | ||||
|    * | ||||
|    * \remarks | ||||
|    * Write remarks for operator [] here. | ||||
|    * | ||||
|    * \see | ||||
|    * Separate items with the '|' character. | ||||
|    */ | ||||
|   ItemType& operator[](LIST_ARRAY_INDEX_TYPE); | ||||
|  | ||||
|  private: | ||||
|   listNode<ItemType>* head; | ||||
|   listNode<ItemType>* tail; | ||||
|   listNode<ItemType>* currPos; | ||||
| }; | ||||
|  | ||||
| template <class ItemType> | ||||
| listNode<ItemType>::listNode() { | ||||
|   next = NULL; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| list<ItemType>::list() { | ||||
|   head = NULL; | ||||
|   tail = NULL; | ||||
|   currPos = NULL; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| list<ItemType>::~list() { | ||||
|   currPos = NULL; | ||||
|   while (head != NULL) { | ||||
|     tail = head; | ||||
|     head = head->next; | ||||
|     delete tail; | ||||
|     tail = NULL; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| list<ItemType>::list(const list<ItemType>& rtOp) { | ||||
|   head = NULL; | ||||
|   tail = NULL; | ||||
|   currPos = NULL; | ||||
|  | ||||
|   operator=(rtOp); | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::Clear() { | ||||
|   while (head) Remove(head->data); | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::operator=(const list<ItemType>& rtOp) { | ||||
|   Clear(); | ||||
|  | ||||
|   if (!rtOp.IsEmpty()) { | ||||
|     listNode<ItemType>* temp = rtOp.head->next; | ||||
|     listNode<ItemType>* temp2 = NULL; | ||||
|  | ||||
|     if (temp != NULL) { | ||||
|       head = new listNode<ItemType>; | ||||
|       head->data = rtOp.head->data; | ||||
|       tail = head; | ||||
|       temp2 = head; | ||||
|     } | ||||
|  | ||||
|     while (temp != NULL) { | ||||
|       temp2->next = new listNode<ItemType>; | ||||
|       temp2 = temp2->next; | ||||
|       temp2->data = temp->data; | ||||
|       temp = temp->next; | ||||
|     } | ||||
|  | ||||
|     tail = temp2; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::IsEmpty() const { | ||||
|   return head == NULL; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::IsFull() const { | ||||
|   return false; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::Insert(ItemType newItem) { | ||||
|   listNode<ItemType>* temp = head; | ||||
|   listNode<ItemType>* temp2 = NULL; | ||||
|  | ||||
|   if (head == NULL) { | ||||
|     temp = tail = head = new listNode<ItemType>; | ||||
|   } else { | ||||
|     if (newItem < head->data) { | ||||
|       temp2 = head; | ||||
|       temp = head = new listNode<ItemType>; | ||||
|       head->next = temp2; | ||||
|       temp2 = NULL; | ||||
|     } else { | ||||
|       // temp = head; | ||||
|       while (temp->next != NULL && newItem > temp->next->data) { | ||||
|         temp = temp->next; | ||||
|       } | ||||
|       temp2 = temp->next; | ||||
|       temp = temp->next = new listNode<ItemType>; | ||||
|       temp->next = temp2; | ||||
|       temp2 = NULL; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   temp->data = newItem; | ||||
|  | ||||
|   if (temp->next == NULL) { | ||||
|     tail = temp; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::Remove(ItemType target) { | ||||
|   if (head != NULL) { | ||||
|     listNode<ItemType>* temp = head; | ||||
|     listNode<ItemType>* temp2 = head; | ||||
|  | ||||
|     while (temp->next != NULL && temp->data != target) { | ||||
|       temp2 = temp; | ||||
|       temp = temp->next; | ||||
|     } | ||||
|  | ||||
|     if (temp->data == target) { | ||||
|       if (temp != head) { | ||||
|         temp2->next = temp->next; | ||||
|         delete temp; | ||||
|       } else { | ||||
|         if (tail == head) tail = NULL; | ||||
|         head = head->next; | ||||
|         delete temp2; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::PrevPosition() { | ||||
|   if (currPos != head) { | ||||
|     tail->next = currPos; | ||||
|     currPos = head; | ||||
|  | ||||
|     if (currPos != tail->next) { | ||||
|       while (currPos->next != tail->next) { | ||||
|         currPos = currPos->next; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     tail->next = NULL; | ||||
|  | ||||
|     return true; | ||||
|   } else { | ||||
|     return false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::NextPosition() { | ||||
|   if (currPos != tail) { | ||||
|     currPos = currPos->next; | ||||
|     return true; | ||||
|   } else { | ||||
|     return false; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::Remove() { | ||||
|   if (currPos != NULL) { | ||||
|     tail->next = currPos; | ||||
|     currPos = currPos->next; | ||||
|     delete tail->next; | ||||
|     tail->next = NULL; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| ItemType list<ItemType>::Retrieve() const { | ||||
|   if (currPos != NULL) return currPos->data; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::IsFirstPosition() const { | ||||
|   return currPos == head; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::IsLastPosition() const { | ||||
|   return currPos == tail; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::FirstPosition() { | ||||
|   currPos = head; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| void list<ItemType>::LastPosition() { | ||||
|   currPos = tail; | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| ItemType list<ItemType>::operator[](LIST_ARRAY_INDEX_TYPE index) const { | ||||
|   if (head == NULL) { | ||||
|     // We should throw an exception here but instead I'll just return shit guess | ||||
|     // for now if somebody does this they're just fucked. | ||||
|   } else { | ||||
|     listNode<ItemType>* temp = head; | ||||
|     LIST_ARRAY_INDEX_TYPE current; | ||||
|  | ||||
|     for (current = 0; current < index; current++) { | ||||
|       if (temp->next == NULL) { | ||||
|         temp->next = new listNode<ItemType>; | ||||
|       } | ||||
|       temp = temp->next; | ||||
|     } | ||||
|     return temp->data; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| ItemType& list<ItemType>::operator[](LIST_ARRAY_INDEX_TYPE index) { | ||||
|   if (head == NULL) { | ||||
|     tail = currPos = head = new listNode<ItemType>; | ||||
|     return (ItemType&)(head->data); | ||||
|   } else { | ||||
|     listNode<ItemType>* temp = head; | ||||
|     LIST_ARRAY_INDEX_TYPE current; | ||||
|  | ||||
|     for (current = 0; current < index; current++) { | ||||
|       if (temp->next == NULL) { | ||||
|         temp->next = new listNode<ItemType>; | ||||
|       } | ||||
|       temp = temp->next; | ||||
|     } | ||||
|     return (ItemType&)(temp->data); | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| unsigned int list<ItemType>::Length() { | ||||
|   if (head == NULL) { | ||||
|     return 0; | ||||
|   } else { | ||||
|     int len = 1; | ||||
|     listNode<ItemType>* temp = head->next; | ||||
|     while (temp != NULL) { | ||||
|       temp = temp->next; | ||||
|       len++; | ||||
|     } | ||||
|     return len; | ||||
|   } | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::Contains(ItemType value) const { | ||||
|   listNode<ItemType>* temp = head; | ||||
|   while (temp != NULL) { | ||||
|     if (temp->data == value) { | ||||
|       return true; | ||||
|     } | ||||
|     temp = temp->next; | ||||
|   } | ||||
|   return false; | ||||
| } | ||||
| };  // namespace OpenArena | ||||
|  | ||||
| #pragma clang diagnostic pop | ||||
| #endif  // End !defined(OpenArena__list_h__) | ||||
		Reference in New Issue
	
	Block a user