HPCToolkit
PointerStack.hpp
Go to the documentation of this file.
1 // -*-Mode: C++;-*-
2 
3 // * BeginRiceCopyright *****************************************************
4 //
5 // $HeadURL$
6 // $Id$
7 //
8 // --------------------------------------------------------------------------
9 // Part of HPCToolkit (hpctoolkit.org)
10 //
11 // Information about sources of support for research and development of
12 // HPCToolkit is at 'hpctoolkit.org' and in 'README.Acknowledgments'.
13 // --------------------------------------------------------------------------
14 //
15 // Copyright ((c)) 2002-2019, Rice University
16 // All rights reserved.
17 //
18 // Redistribution and use in source and binary forms, with or without
19 // modification, are permitted provided that the following conditions are
20 // met:
21 //
22 // * Redistributions of source code must retain the above copyright
23 // notice, this list of conditions and the following disclaimer.
24 //
25 // * Redistributions in binary form must reproduce the above copyright
26 // notice, this list of conditions and the following disclaimer in the
27 // documentation and/or other materials provided with the distribution.
28 //
29 // * Neither the name of Rice University (RICE) nor the names of its
30 // contributors may be used to endorse or promote products derived from
31 // this software without specific prior written permission.
32 //
33 // This software is provided by RICE and contributors "as is" and any
34 // express or implied warranties, including, but not limited to, the
35 // implied warranties of merchantability and fitness for a particular
36 // purpose are disclaimed. In no event shall RICE or contributors be
37 // liable for any direct, indirect, incidental, special, exemplary, or
38 // consequential damages (including, but not limited to, procurement of
39 // substitute goods or services; loss of use, data, or profits; or
40 // business interruption) however caused and on any theory of liability,
41 // whether in contract, strict liability, or tort (including negligence
42 // or otherwise) arising in any way out of the use of this software, even
43 // if advised of the possibility of such damage.
44 //
45 // ******************************************************* EndRiceCopyright *
46 
47 //***************************************************************************
48 //
49 // PointerStack.h:
50 //
51 // Author: John Mellor-Crummey October 1993
52 //
53 // rjf 2-21-98 Replaced previous versions of PointerStack with
54 // a self-contained implementaion for efficiency and
55 // to avoid using templates when building runtime libraries
56 // on machines on which the compiler itself does not run.
57 //***************************************************************************
58 
59 #ifndef PointerStack_h
60 #define PointerStack_h
61 
62 //************************** System Include Files ***************************
63 
64 //*************************** User Include Files ****************************
65 
66 //*************************** Forward Declarations **************************
67 
68 //***************************************************************************
69 
70 class PointerStack {
72  int lastSlot;
73  void **theStack;
74  void ExtendAndPush( void* item);
75 public:
76  PointerStack(unsigned int initialSize = 32);
77  ~PointerStack();
78 
79  void Push(void *item) { // push a new item on the top of the stack
80  if ( topElement < lastSlot ) {
81  theStack[++topElement] = item;
82  }
83  else
84  ExtendAndPush(item);
85  };
86 
87  void *Pop() {
88  return (topElement >=0) // pop and return the top item (0 when empty)
89  ? theStack[topElement--]
90  : (void *) 0 ;
91  };
92 
93  void *Top(){
94  return (topElement >=0) // return the top item (0 when empty)
95  ? theStack[topElement]
96  : (void *) 0 ;
97  };
98 
99  // return the item that is "depth" elements from the top of the stack
100  // Get(0) returns the top of the stack (0 when empty)
101  void *Get(unsigned int depth) {
102  // eraxxon: changed to eliminate comparison between unsigned/signed
103  if (topElement >= 0) {
104  return (depth <= (unsigned int)topElement)
105  ? theStack[topElement - depth]
106  : (void *) 0 ;
107  } else {
108  return (void *) 0 ;
109  }
110  };
111 
112  unsigned int Depth() { // 0 when empty
113  return (topElement + 1) ;
114  } ;
115 
116 };
117 
118 #endif
119 
120 
121 
122 
void ** theStack
PointerStack(unsigned int initialSize=32)
void * Top()
void ExtendAndPush(void *item)
void Push(void *item)
unsigned int Depth()
void * Get(unsigned int depth)
void * Pop()