HPCToolkit
IteratorStack.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 // IteratorStack.h
49 //
50 // an iterator that is realized as a stack of iterators. this abstraction
51 // is useful for traversing nested structures.
52 //
53 // Author: John Mellor-Crummey
54 //
55 // Creation Date: October 1993
56 //
57 // Modification History:
58 // November 1994 -- John Mellor-Crummey
59 //
60 //**************************************************************************/
61 
62 
63 #ifndef IteratorStack_h
64 #define IteratorStack_h
65 
66 //************************** System Include Files ***************************
67 
68 //*************************** User Include Files ****************************
69 
70 #include <include/uint.h>
71 
72 #include "StackableIterator.hpp"
73 
74 //*************************** Forward Declarations **************************
75 
76 //***************************************************************************
77 
78 //****************************************************************************
79 // enumeration type declarations
80 //***************************************************************************/
81 
83 
86 };
87 
88 
89 
90 //****************************************************************************
91 // class IteratorStack
92 //***************************************************************************/
93 
95 public:
99 
100 public:
101 
104  ~IteratorStack();
105 
106  void *CurrentUpCall() const;
107 
108  void operator++(int); // postfix increment
109  void operator++(); // prefix increment
110 
111  // pop all but one iterator off the stack; reset the one left
112  void Reset(); // same traversal order as before
113  void Reset(TraversalOrder torder,
115 
116  // empty the stack and reset the state to that as if freshly constructed
117  void ReConstruct(TraversalOrder torder,
119 
120  bool IsValid() const;
121 
122  virtual TraversalVisitType VisitType() const;
124  virtual bool IterationIsForward() const;
125 
126  void DumpUpCall();
127 
128 protected:
129  TraversalOrder clientTraversalOrder; // client supplied traversal order
131 
132  void Push(StackableIterator *);
133  StackableIterator *Top(void) const;
134  StackableIterator *GetIteratorAtPosition(unsigned int depth) const; // TOS=0
135  void FreeTop();
136 
137  int Depth() const;
138 
139 private:
140  virtual StackableIterator *IteratorToPushIfAny(void *current) = 0;
141 
142  void FreeStack(int maxDepth);
143  void InitTraversal(TraversalOrder torder, IterStackEnumType enumType);
144 
146  TraversalOrder traversalOrder; // internally computed traversal order
147 };
148 
149 //****************************************************************************
150 // class SingletonIterator
151 //***************************************************************************/
152 
154 public:
155  SingletonIterator(const void* singletonValue, TraversalVisitType vtype);
157 
158  void* CurrentUpCall() const;
159  void operator++();
160  void operator++(int);
161  void Reset();
162 
164 
165 private:
166  const void* value;
167  bool done;
169 };
170 
171 
172 #endif
void ReConstruct(TraversalOrder torder, IterStackEnumType enumType=ITER_STACK_ENUM_ALL_NODES)
struct IteratorStackS * iteratorStackRepr
IterStackEnumType
TraversalOrder clientTraversalOrder
StackableIterator * Top(void) const
virtual bool IterationIsForward() const
TraversalVisitType
void FreeStack(int maxDepth)
virtual StackableIterator * IteratorToPushIfAny(void *current)=0
IterStackEnumType enumType
IteratorStack(TraversalOrder torder, IterStackEnumType enumType=ITER_STACK_ENUM_ALL_NODES)
TraversalOrder GetTraversalOrder() const
const void * value
void InitTraversal(TraversalOrder torder, IterStackEnumType enumType)
bool IsValid() const
StackableIterator * GetIteratorAtPosition(unsigned int depth) const
virtual TraversalVisitType VisitType() const
TraversalOrder traversalOrder
void Push(StackableIterator *)
TraversalVisitType visitType
int Depth() const
void * CurrentUpCall() const