Mercurial > projects > hoofbaby
comparison deps/Platinum/ThirdParty/Neptune/Source/Core/NptQueue.h @ 0:3425707ddbf6
Initial import (hopefully this mercurial stuff works...)
author | fraserofthenight |
---|---|
date | Mon, 06 Jul 2009 08:06:28 -0700 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:3425707ddbf6 |
---|---|
1 /***************************************************************** | |
2 | | |
3 | Neptune - Queue | |
4 | | |
5 | Copyright (c) 2002-2008, Axiomatic Systems, LLC. | |
6 | All rights reserved. | |
7 | | |
8 | Redistribution and use in source and binary forms, with or without | |
9 | modification, are permitted provided that the following conditions are met: | |
10 | * Redistributions of source code must retain the above copyright | |
11 | notice, this list of conditions and the following disclaimer. | |
12 | * Redistributions in binary form must reproduce the above copyright | |
13 | notice, this list of conditions and the following disclaimer in the | |
14 | documentation and/or other materials provided with the distribution. | |
15 | * Neither the name of Axiomatic Systems nor the | |
16 | names of its contributors may be used to endorse or promote products | |
17 | derived from this software without specific prior written permission. | |
18 | | |
19 | THIS SOFTWARE IS PROVIDED BY AXIOMATIC SYSTEMS ''AS IS'' AND ANY | |
20 | EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | |
21 | WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |
22 | DISCLAIMED. IN NO EVENT SHALL AXIOMATIC SYSTEMS BE LIABLE FOR ANY | |
23 | DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | |
24 | (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | |
25 | LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | |
26 | ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
27 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | |
28 | SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
29 | | |
30 ****************************************************************/ | |
31 | |
32 #ifndef _NPT_QUEUE_H_ | |
33 #define _NPT_QUEUE_H_ | |
34 | |
35 /*---------------------------------------------------------------------- | |
36 | includes | |
37 +---------------------------------------------------------------------*/ | |
38 #include "NptTypes.h" | |
39 #include "NptConstants.h" | |
40 | |
41 /*---------------------------------------------------------------------- | |
42 | NPT_QueueItem | |
43 +---------------------------------------------------------------------*/ | |
44 class NPT_QueueItem; | |
45 | |
46 /*---------------------------------------------------------------------- | |
47 | NPT_GenericQueue | |
48 +---------------------------------------------------------------------*/ | |
49 class NPT_GenericQueue | |
50 { | |
51 public: | |
52 // class methods | |
53 static NPT_GenericQueue* CreateInstance(NPT_Cardinal max_items = 0); | |
54 | |
55 // methods | |
56 virtual ~NPT_GenericQueue() {} | |
57 virtual NPT_Result Push(NPT_QueueItem* item, | |
58 NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) = 0; | |
59 virtual NPT_Result Pop(NPT_QueueItem*& item, | |
60 NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) = 0; | |
61 virtual NPT_Result Peek(NPT_QueueItem*& item, | |
62 NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) = 0; | |
63 protected: | |
64 // methods | |
65 NPT_GenericQueue() {} | |
66 }; | |
67 | |
68 /*---------------------------------------------------------------------- | |
69 | NPT_Queue | |
70 +---------------------------------------------------------------------*/ | |
71 template <class T> | |
72 class NPT_Queue | |
73 { | |
74 public: | |
75 // methods | |
76 NPT_Queue(NPT_Cardinal max_items = 0) : | |
77 m_Delegate(NPT_GenericQueue::CreateInstance(max_items)) {} | |
78 virtual ~NPT_Queue<T>() { delete m_Delegate; } | |
79 virtual NPT_Result Push(T* item, NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) { | |
80 return m_Delegate->Push(reinterpret_cast<NPT_QueueItem*>(item), timeout); | |
81 } | |
82 virtual NPT_Result Pop(T*& item, NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) { | |
83 return m_Delegate->Pop(reinterpret_cast<NPT_QueueItem*&>(item), | |
84 timeout); | |
85 } | |
86 virtual NPT_Result Peek(T*& item, NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) { | |
87 return m_Delegate->Peek(reinterpret_cast<NPT_QueueItem*&>(item), | |
88 timeout); | |
89 } | |
90 | |
91 protected: | |
92 // members | |
93 NPT_GenericQueue* m_Delegate; | |
94 }; | |
95 | |
96 #endif // _NPT_QUEUE_H_ |