kodi
NptStack.h
1 /*****************************************************************
2 |
3 | Neptune - Stack
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_STACK_H_
33 #define _NPT_STACK_H_
34 
35 /*----------------------------------------------------------------------
36 | includes
37 +---------------------------------------------------------------------*/
38 #include "NptResults.h"
39 #include "NptTypes.h"
40 #include "NptList.h"
41 
42 /*----------------------------------------------------------------------
43 | NPT_Stack
44 +---------------------------------------------------------------------*/
45 template <typename T>
46 class NPT_Stack : public NPT_List<T>
47 {
48 public:
49  // methods
50  NPT_Result Push(const T& value) {
51  // NOTE: we must use the this-> accessor here because the standard
52  // requires it when the member to look up is in a parent template
53  return this->Add(value);
54  }
55 
56  NPT_Result Peek(T& value) {
57  // NOTE: we must use the this-> accessor here because the standard
58  // requires it when the member to look up is in a parent template
59  if (this->m_ItemCount == 0) return NPT_ERROR_NO_SUCH_ITEM;
60  value = this->m_Tail->m_Data;
61  return NPT_SUCCESS;
62  }
63 
64  NPT_Result Pop(T& value) {
65  // NOTE: we must use the this-> accessor here because the standard
66  // requires it when the member to look up is in a parent template
67  if (this->m_ItemCount == 0) return NPT_ERROR_NO_SUCH_ITEM;
68  typename NPT_List<T>::Iterator tail = this->GetLastItem();
69  value = *tail;
70  return this->Erase(tail);
71  }
72 };
73 
74 #endif // _NPT_STACK_H_
Definition: NptList.h:63
Definition: NptStack.h:46
Definition: NptList.h:54