Changed Moved template List<class> into namespace OpenArena
~g2k
This commit is contained in:
		
							
								
								
									
										669
									
								
								include/list.h
									
									
									
									
									
								
							
							
						
						
									
										669
									
								
								include/list.h
									
									
									
									
									
								
							| @@ -5,375 +5,376 @@ | ||||
|  | ||||
| #pragma warning(disable:4715) | ||||
|  | ||||
| typedef unsigned int LIST_ARRAY_INDEX_TYPE; | ||||
| namespace OpenArena{ | ||||
| 	typedef unsigned int LIST_ARRAY_INDEX_TYPE; | ||||
|  | ||||
| template <class ItemType> | ||||
| class listNode | ||||
| { | ||||
| public: | ||||
| 	listNode(); | ||||
| 	ItemType data; | ||||
| 	listNode<ItemType>* next; | ||||
| }; | ||||
|  | ||||
| template <class ItemType> | ||||
| class list | ||||
| { | ||||
| public: | ||||
| 	list(); | ||||
| 	~list(); | ||||
| 	list(const list&); | ||||
|  | ||||
| 	bool IsEmpty() const; | ||||
| 	bool IsFull() const; | ||||
| 	void Insert(ItemType newItem); | ||||
| 	void Remove(ItemType target); | ||||
| 	void Remove(); | ||||
| 	ItemType Retrieve() const; | ||||
| 	bool PrevPosition(); | ||||
| 	bool NextPosition(); | ||||
| 	bool IsFirstPosition() const; | ||||
| 	bool IsLastPosition() const; | ||||
| 	void FirstPosition(); | ||||
| 	void LastPosition(); | ||||
| 	void Clear(); | ||||
| 	bool Contains(ItemType) const; | ||||
| 	unsigned int Length(); | ||||
| 	void operator=(const list<ItemType>&); | ||||
| 	ItemType operator[](LIST_ARRAY_INDEX_TYPE) const; | ||||
| 	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) | ||||
| 	template <class ItemType> | ||||
| 	class listNode | ||||
| 	{ | ||||
| 		tail = head; | ||||
| 		head = head->next; | ||||
| 		delete tail; | ||||
| 		tail = NULL; | ||||
| 	public: | ||||
| 		listNode(); | ||||
| 		ItemType data; | ||||
| 		listNode<ItemType>* next; | ||||
| 	}; | ||||
|  | ||||
| 	template <class ItemType> | ||||
| 	class list | ||||
| 	{ | ||||
| 	public: | ||||
| 		list(); | ||||
| 		~list(); | ||||
| 		list(const list&); | ||||
|  | ||||
| 		bool IsEmpty() const; | ||||
| 		bool IsFull() const; | ||||
| 		void Insert(ItemType newItem); | ||||
| 		void Remove(ItemType target); | ||||
| 		void Remove(); | ||||
| 		ItemType Retrieve() const; | ||||
| 		bool PrevPosition(); | ||||
| 		bool NextPosition(); | ||||
| 		bool IsFirstPosition() const; | ||||
| 		bool IsLastPosition() const; | ||||
| 		void FirstPosition(); | ||||
| 		void LastPosition(); | ||||
| 		void Clear(); | ||||
| 		bool Contains(ItemType) const; | ||||
| 		unsigned int Length(); | ||||
| 		void operator=(const list<ItemType>&); | ||||
| 		ItemType operator[](LIST_ARRAY_INDEX_TYPE) const; | ||||
| 		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(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()) | ||||
| 	template <class ItemType> | ||||
| 	list<ItemType>::list() | ||||
| 	{ | ||||
| 		listNode<ItemType>* temp = rtOp.head->next; | ||||
| 		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(temp != NULL) | ||||
| 		if(head == 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; | ||||
| 			temp = tail = head = new listNode<ItemType>; | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			//temp = head; | ||||
| 			while(temp->next != NULL && newItem > temp->next->data) | ||||
| 			if(newItem < head->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; | ||||
| 				temp2 = head; | ||||
| 				temp = head = new listNode<ItemType>; | ||||
| 				head->next = temp2; | ||||
| 				temp2 = NULL; | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				if(tail == head) | ||||
| 					tail = NULL; | ||||
| 				head = head->next; | ||||
| 				delete temp2; | ||||
| 				//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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| bool list<ItemType>::PrevPosition() | ||||
| { | ||||
| 	if(currPos != head) | ||||
| 	{ | ||||
| 		tail->next = currPos; | ||||
| 		currPos = head; | ||||
| 		 | ||||
| 		if(currPos != tail->next) | ||||
| 		temp->data = newItem; | ||||
|  | ||||
| 		if(temp->next == NULL) | ||||
| 		{ | ||||
|             while(currPos->next != tail->next) | ||||
| 			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) | ||||
| 			{ | ||||
| 				currPos = currPos->next; | ||||
| 				temp2 = temp; | ||||
| 				temp = temp->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) | ||||
| 			if(temp->data == target) | ||||
| 			{ | ||||
| 				temp->next = new listNode<ItemType>; | ||||
| 				if(temp != head) | ||||
| 				{ | ||||
| 					temp2->next = temp->next; | ||||
| 					delete temp; | ||||
| 				} | ||||
| 				else | ||||
| 				{ | ||||
| 					if(tail == head) | ||||
| 						tail = NULL; | ||||
| 					head = head->next; | ||||
| 					delete temp2; | ||||
| 				} | ||||
| 			} | ||||
| 			temp = temp->next; | ||||
| 		} | ||||
| 		return temp->data; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| template <class ItemType> | ||||
| ItemType& list<ItemType>::operator[](LIST_ARRAY_INDEX_TYPE index) | ||||
| { | ||||
| 	if(head == NULL) | ||||
| 	template <class ItemType> | ||||
| 	bool list<ItemType>::PrevPosition() | ||||
| 	{ | ||||
| 		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(currPos != head) | ||||
| 		{ | ||||
| 			if(temp->next == NULL) | ||||
| 			tail->next = currPos; | ||||
| 			currPos = head; | ||||
|  | ||||
| 			if(currPos != tail->next) | ||||
| 			{ | ||||
| 				temp->next = new listNode<ItemType>; | ||||
| 				while(currPos->next != tail->next) | ||||
| 				{ | ||||
| 					currPos = currPos->next; | ||||
| 				} | ||||
| 			} | ||||
| 			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; | ||||
| 	} | ||||
| } | ||||
| 			tail->next = NULL; | ||||
|  | ||||
| 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; | ||||
| 		else | ||||
| 		{ | ||||
| 			return false; | ||||
| 		} | ||||
| 	} | ||||
| 	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;	 | ||||
| 	} | ||||
| }; | ||||
| #endif | ||||
|   | ||||
		Reference in New Issue
	
	Block a user