openmohaa/code/qcommon/queue.h

241 lines
3.3 KiB
C
Raw Permalink Normal View History

2016-03-27 11:49:47 +02:00
/*
===========================================================================
Copyright (C) 2015 the OpenMoHAA team
This file is part of OpenMoHAA source code.
OpenMoHAA source code 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.
OpenMoHAA source code 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 OpenMoHAA source code; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
===========================================================================
*/
// queue.h: Generic Queue object
//
#ifndef __QUEUE_H__
#define __QUEUE_H__
#include "class.h"
template<class T>
2016-03-27 11:49:47 +02:00
class QueueNode : public Class
{
public:
T data;
QueueNode *next;
2016-03-27 11:49:47 +02:00
QueueNode();
};
2016-03-27 11:49:47 +02:00
template<class T>
QueueNode<T>::QueueNode()
{
2016-03-27 11:49:47 +02:00
data = NULL;
next = NULL;
}
2016-03-27 11:49:47 +02:00
template<class T>
2016-03-27 11:49:47 +02:00
class Queue : public Class
{
private:
QueueNode<T> *head;
QueueNode<T> *tail;
public:
Queue();
~Queue();
void Clear(void);
qboolean Empty(void);
void Enqueue(T data);
T Dequeue(void);
void Remove(T data);
qboolean Inqueue(T data);
};
template<class T>
qboolean Queue<T>::Empty
2016-03-27 11:49:47 +02:00
(
void
)
{
if (head == NULL)
2016-03-27 11:49:47 +02:00
{
assert(!tail);
2016-03-27 11:49:47 +02:00
return true;
}
2016-03-27 11:49:47 +02:00
assert(tail);
2016-03-27 11:49:47 +02:00
return false;
}
2016-03-27 11:49:47 +02:00
template<class T>
void Queue<T>::Enqueue
2016-03-27 11:49:47 +02:00
(
T data
2016-03-27 11:49:47 +02:00
)
{
QueueNode<T> *tmp;
2016-03-27 11:49:47 +02:00
tmp = new QueueNode<T>;
assert(tmp);
2016-03-27 11:49:47 +02:00
tmp->data = data;
assert(!tmp->next);
if (!head)
{
assert(!tail);
2016-03-27 11:49:47 +02:00
head = tmp;
}
2016-03-27 11:49:47 +02:00
else
{
assert(tail);
2016-03-27 11:49:47 +02:00
tail->next = tmp;
}
tail = tmp;
}
2016-03-27 11:49:47 +02:00
template<class T>
T Queue<T>::Dequeue
2016-03-27 11:49:47 +02:00
(
void
)
{
T ptr;
QueueNode<T> *node;
2016-03-27 11:49:47 +02:00
if (!head)
{
assert(!tail);
2016-03-27 11:49:47 +02:00
return NULL;
}
2016-03-27 11:49:47 +02:00
node = head;
ptr = node->data;
head = node->next;
if (head == NULL)
{
assert(tail == node);
2016-03-27 11:49:47 +02:00
tail = NULL;
}
2016-03-27 11:49:47 +02:00
delete node;
return ptr;
}
2016-03-27 11:49:47 +02:00
template<class T>
void Queue<T>::Clear
2016-03-27 11:49:47 +02:00
(
void
)
{
while (!Empty())
2016-03-27 11:49:47 +02:00
{
Dequeue();
}
}
2016-03-27 11:49:47 +02:00
template<class T>
Queue<T>::Queue()
{
2016-03-27 11:49:47 +02:00
head = NULL;
tail = NULL;
}
template<class T>
Queue<T>::~Queue()
{
Clear();
}
template<class T>
void Queue<T>::Remove
(
T data
)
{
QueueNode<T> *node;
QueueNode<T> *prev;
if (!head)
{
assert(!tail);
gi.DPrintf("Queue::Remove : Data not found in queue\n");
return;
2016-03-27 11:49:47 +02:00
}
for (prev = NULL, node = head; node != NULL; prev = node, node = node->next)
2016-03-27 11:49:47 +02:00
{
if (node->data == data)
{
break;
}
}
if (!node)
{
gi.DPrintf("Queue::Remove : Data not found in queue\n");
}
else
{
if (!prev)
{
// at head
assert(node == head);
head = node->next;
if (head == NULL)
{
assert(tail == node);
tail = NULL;
}
}
else
{
prev->next = node->next;
if (prev->next == NULL)
{
// at tail
assert(tail == node);
tail = prev;
}
}
delete node;
2016-03-27 11:49:47 +02:00
}
}
2016-03-27 11:49:47 +02:00
template<class T>
qboolean Queue<T>::Inqueue
(
T data
)
{
QueueNode<T> *node;
2016-03-27 11:49:47 +02:00
for (node = head; node != NULL; node = node->next)
{
if (node->data == data)
2016-03-27 11:49:47 +02:00
{
return true;
2016-03-27 11:49:47 +02:00
}
}
2016-03-27 11:49:47 +02:00
return false;
}
2016-03-27 11:49:47 +02:00
#endif /* queue.h */