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
75
class
StackableIterator
{
76
public
:
77
StackableIterator
();
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
StackableIterator::CurrentUpCall
virtual void * CurrentUpCall() const =0
uint.h
StackableIterator::operator++
virtual void operator++()=0
StackableIterator::Reset
virtual void Reset()=0
StackableIterator::IsValid
virtual bool IsValid() const
Definition:
StackableIterator.cpp:95
StackableIterator
Definition:
StackableIterator.hpp:75
StackableIterator::DumpUpCall
virtual void DumpUpCall()
Definition:
StackableIterator.cpp:111
StackableIterator::StackableIterator
StackableIterator()
Definition:
StackableIterator.cpp:78
StackableIterator::~StackableIterator
virtual ~StackableIterator()
Definition:
StackableIterator.cpp:84
StackableIterator::Dump
void Dump()
Definition:
StackableIterator.cpp:101
src
lib
support
StackableIterator.hpp
Generated by
1.8.13