|
Last change
on this file since 21892 was 21708, checked in by dmik, 14 years ago |
|
Don't use class name suffix in declaration.
This is superfluous and fatal for GCC.
|
|
File size:
1.6 KB
|
| Line | |
|---|
| 1 | /* $Id: queue.h,v 1.1 2000-03-09 19:03:20 sandervl Exp $ */
|
|---|
| 2 |
|
|---|
| 3 | /*
|
|---|
| 4 | * Very simply generic queue class
|
|---|
| 5 | *
|
|---|
| 6 | * Copyright 2000 Sander van Leeuwen (sandervl@xs4all.nl)
|
|---|
| 7 | *
|
|---|
| 8 | * Project Odin Software License can be found in LICENSE.TXT
|
|---|
| 9 | *
|
|---|
| 10 | */
|
|---|
| 11 |
|
|---|
| 12 | class Queue;
|
|---|
| 13 |
|
|---|
| 14 | //******************************************************************************
|
|---|
| 15 | //******************************************************************************
|
|---|
| 16 | class QueueItem
|
|---|
| 17 | {
|
|---|
| 18 | public:
|
|---|
| 19 | QueueItem(ULONG dwItemData)
|
|---|
| 20 | {
|
|---|
| 21 | this->dwItemData = dwItemData;
|
|---|
| 22 | next = NULL;
|
|---|
| 23 | }
|
|---|
| 24 |
|
|---|
| 25 | private:
|
|---|
| 26 | ULONG dwItemData;
|
|---|
| 27 | QueueItem *next;
|
|---|
| 28 |
|
|---|
| 29 | friend class Queue;
|
|---|
| 30 | };
|
|---|
| 31 | //******************************************************************************
|
|---|
| 32 | //******************************************************************************
|
|---|
| 33 | class Queue
|
|---|
| 34 | {
|
|---|
| 35 | public:
|
|---|
| 36 | Queue();
|
|---|
| 37 | ~Queue();
|
|---|
| 38 |
|
|---|
| 39 | void Push(ULONG dwItemData);
|
|---|
| 40 | void Remove(ULONG dwItemData);
|
|---|
| 41 | void Remove(QueueItem *item);
|
|---|
| 42 | ULONG Pop();
|
|---|
| 43 |
|
|---|
| 44 | void operator=(Queue&) ;
|
|---|
| 45 |
|
|---|
| 46 | QueueItem *Head() { return head; };
|
|---|
| 47 | QueueItem *Tail() { return tail; };
|
|---|
| 48 | QueueItem *getNext(QueueItem *item) { return item->next; };
|
|---|
| 49 | ULONG getItem(QueueItem *item) { return item->dwItemData; };
|
|---|
| 50 |
|
|---|
| 51 | BOOL hasElements() { return head != NULL; };
|
|---|
| 52 |
|
|---|
| 53 | private:
|
|---|
| 54 | void PushRev(Queue& queue, QueueItem *item);
|
|---|
| 55 |
|
|---|
| 56 | QueueItem *head;
|
|---|
| 57 | QueueItem *tail;
|
|---|
| 58 | };
|
|---|
| 59 | //******************************************************************************
|
|---|
| 60 | //******************************************************************************
|
|---|
| 61 |
|
|---|
Note:
See
TracBrowser
for help on using the repository browser.