HPCToolkit
StackableIterator.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 // StackableIterator.h
49 //
50 // a base set of functionality for iterators that can be used with the
51 // IteratorStack abstraction to traverse nested structures
52 //
53 // Author: John Mellor-Crummey
54 //
55 // Creation Date: October 1993
56 //
57 //***************************************************************************
58 
59 
60 #ifndef StackableIterator_h
61 #define StackableIterator_h
62 
63 //************************** System Include Files ***************************
64 
65 //*************************** User Include Files ****************************
66 
67 #include <include/uint.h>
68 
69 //*************************** Forward Declarations **************************
70 
71 //***************************************************************************
72 // class StackableIterator
73 //***************************************************************************
74 
76 public:
78  virtual ~StackableIterator();
79 
80  //----------------------------------------------------------------------
81  // upcall to get the value of the current element in the iteration from
82  // a derived iterator
83  //----------------------------------------------------------------------
84  virtual void *CurrentUpCall() const = 0;
85 
86  //----------------------------------------------------------------------
87  // upcall to advance the iteration
88  //----------------------------------------------------------------------
89  virtual void operator++() = 0; // prefix increment
90  void operator++(int); // postincrement via preincrement operator
91 
92  //----------------------------------------------------------------------
93  // predicate to test if the value returned by CurrentUpCall is valid.
94  // supplied default implementation returns true if the value is non-zero
95  //----------------------------------------------------------------------
96  virtual bool IsValid() const;
97 
98  //----------------------------------------------------------------------
99  // upcall to restart the iteration at the beginning
100  //----------------------------------------------------------------------
101  virtual void Reset() = 0;
102 
103  //----------------------------------------------------------------------
104  // dump essential state (class name, this pointer, currrent iterate)
105  // and invoke DumpUpCall to report interesting state of derived class
106  //----------------------------------------------------------------------
107  void Dump();
108 
109 private:
110  //----------------------------------------------------------------------
111  // upcall to dump any interesting state of a derived class
112  //----------------------------------------------------------------------
113  virtual void DumpUpCall();
114 };
115 
116 #endif
117 
virtual void * CurrentUpCall() const =0
virtual void operator++()=0
virtual void Reset()=0
virtual bool IsValid() const
virtual void DumpUpCall()