Merge pull request #25959 from neo1973/TagLib_deprecation_warnings
[xbmc.git] / lib / libUPnP / Neptune / Source / Core / NptQueue.h
blobb4f6baee1b46bf1889397d25251c9d310d6fcb44
1 /*****************************************************************
3 | Neptune - Queue
5 | Copyright (c) 2002-2008, Axiomatic Systems, LLC.
6 | All rights reserved.
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.
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.
30 ****************************************************************/
32 #ifndef _NPT_QUEUE_H_
33 #define _NPT_QUEUE_H_
35 /*----------------------------------------------------------------------
36 | includes
37 +---------------------------------------------------------------------*/
38 #include "NptTypes.h"
39 #include "NptConstants.h"
41 /*----------------------------------------------------------------------
42 | NPT_QueueItem
43 +---------------------------------------------------------------------*/
44 class NPT_QueueItem;
46 /*----------------------------------------------------------------------
47 | NPT_GenericQueue
48 +---------------------------------------------------------------------*/
49 class NPT_GenericQueue
51 public:
52 // class methods
53 static NPT_GenericQueue* CreateInstance(NPT_Cardinal max_items = 0);
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() {}
68 /*----------------------------------------------------------------------
69 | NPT_Queue
70 +---------------------------------------------------------------------*/
71 template <class T>
72 class NPT_Queue
74 public:
75 // methods
76 NPT_Queue(NPT_Cardinal max_items = 0) :
77 m_Delegate(NPT_GenericQueue::CreateInstance(max_items)) {}
78 virtual ~NPT_Queue() { 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);
82 virtual NPT_Result Pop(T*& item, NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) {
83 return m_Delegate->Pop(reinterpret_cast<NPT_QueueItem*&>(item), timeout);
85 virtual NPT_Result Peek(T*& item, NPT_Timeout timeout = NPT_TIMEOUT_INFINITE) {
86 return m_Delegate->Peek(reinterpret_cast<NPT_QueueItem*&>(item), timeout);
89 protected:
90 // members
91 NPT_GenericQueue* m_Delegate;
94 #endif // _NPT_QUEUE_H_