Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
//========= Copyright Valve Corporation, All rights reserved. ============//
//
// Purpose:
//
// $NoKeywords: $
//
//=============================================================================//
#include <stdio.h>
#include <malloc.h>
#include "ObjectList.h"
#include "tier1/strtools.h"
//#include "port.h"
//#include "mem.h"
// memdbgon must be the last include file in a .cpp file!!!
#include <tier0/memdbgon.h>
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
ObjectList::ObjectList() { head = tail = current = NULL; number = 0; }
ObjectList::~ObjectList() { Clear( false ); }
bool ObjectList::AddHead(void * newObject) { // create new element
element_t * newElement = (element_t *) calloc(1, sizeof(element_t));
if (newElement == NULL ) return false; // out of memory
// insert element
newElement->object = newObject;
if (head) { newElement->next = head; head->prev = newElement; };
head = newElement; // if list was empty set new tail
if (tail==NULL) tail = head;
number++;
return true;
}
void * ObjectList::RemoveHead() { void * retObj; // check head is present
if (head) { retObj = head->object; element_t * newHead = head->next; if (newHead) newHead->prev = NULL;
// if only one element is in list also update tail
// if we remove this prev element
if (tail==head) tail = NULL;
free(head); head = newHead;
number--;
} else retObj = NULL;
return retObj; }
bool ObjectList::AddTail(void * newObject) { element_t * newElement = (element_t *) calloc(1, sizeof(element_t));
if (newElement == NULL) return false; // out of memory;
newElement->object = newObject;
if (tail) { newElement->prev = tail; tail->next = newElement; }
tail = newElement;
// if list was empty set new head
if (head==NULL) head = tail;
number++;
return true;
}
void * ObjectList::RemoveTail() { void * retObj; // check tail is present
if (tail) { retObj = tail->object; element_t * newTail = tail->prev; if (newTail) newTail->next = NULL;
// if only one element is in list also update tail
// if we remove this prev element
if (head==tail) head = NULL;
free(tail); tail = newTail;
number--;
} else retObj = NULL;
return retObj; }
bool ObjectList::IsEmpty() { return ( head == NULL ); }
int ObjectList::CountElements() { return number; }
bool ObjectList::Contains(void * object) { element_t * e = head;
while(e && e->object!=object) { e = e->next;}
if ( e ) { current = e; return true; } else { return false; } }
void ObjectList::Clear( bool freeElementsMemory ) { element_t * ne;
element_t * e = head; while(e) { ne = e->next;
if ( freeElementsMemory && e->object ) free( e->object );
free(e); e = ne; }
head = tail = current = NULL; number = 0;
}
bool ObjectList::Remove( void * object ) { element_t * e = head;
while(e && e->object!=object) { e = e->next;}
if (e!=NULL) { if (e->prev) e->prev->next = e->next; if (e->next) e->next->prev = e->prev; if (head==e) head = e->next; if (tail==e) tail = e->prev; if (current == e) current= e->next; free(e); number--; }
return (e!=NULL); }
void ObjectList::Init() { head = tail = current = NULL; number = 0; }
void * ObjectList::GetFirst() { if (head) { current = head->next; return head->object; } else { current = NULL; return NULL; }; }
void * ObjectList::GetNext() { void * retObj = NULL; if (current) { retObj = current->object; current = current->next; } return retObj; }
bool ObjectList::Add(void *newObject) { return AddTail( newObject ); }
|