blob: 6b987d3f657aed2f502c088ccad9b95a65c53ca7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
/* -*- c++ -*- */
//=============================================================================
/**
* @file be_visitor_scope.h
*
* $Id$
*
* Concrete visitor for the base "BE_Scope" node
*
*
* @author Aniruddha Gokhale and Carlos O'Ryan
*/
//=============================================================================
#ifndef TAO_BE_VISITOR_SCOPE_H
#define TAO_BE_VISITOR_SCOPE_H
#include "be_visitor_decl.h"
/**
* @class be_visitor_scope
*
* @brief be_visitor_scope
*
* This is a concrete visitor for the be_scope node. Its only purpose is to
* iterate over the elements of the scope
*/
class be_visitor_scope : public be_visitor_decl
{
public:
/// constructor
be_visitor_scope (be_visitor_context *ctx);
/// destructor
~be_visitor_scope (void);
/// visit scope
int visit_scope (be_scope *node);
/// do any processing after every element except the last one of the scope is
/// processed
virtual int post_process (be_decl *);
/// do any processing prior to processing the element in the scope
virtual int pre_process (be_decl *);
/// return the element number that is being processed
virtual int elem_number (void);
/// get the successor to elem
virtual int next_elem (be_decl *elem, be_decl *&);
/// Is bd the last node in the scope
virtual bool last_node (be_decl *bd);
/// Is bd the last inout or out in the scope
bool last_inout_or_out_node (be_decl *bd);
protected:
int elem_number_;
};
#endif // TAO_BE_VISITOR_SCOPE_H
|