source: src/ControlStruct/LabelFixer.h @ 82dd287

ADTaaron-thesisarm-ehast-experimentalcleanup-dtorsctordeferred_resndemanglerenumforall-pointer-decaygc_noraiijacob/cs343-translationjenkins-sandboxmemorynew-astnew-ast-unique-exprnew-envno_listpersistent-indexerpthread-emulationqualifiedEnumresolv-newstringwith_gc
Last change on this file since 82dd287 was 82dd287, checked in by Aaron Moss <a3moss@…>, 9 years ago

Doc comments

  • Property mode set to 100644
File size: 4.0 KB
Line 
1//
2// Cforall Version 1.0.0 Copyright (C) 2015 University of Waterloo
3//
4// The contents of this file are covered under the licence agreement in the
5// file "LICENCE" distributed with Cforall.
6//
7// LabelFixer.h --
8//
9// Author           : Rodolfo G. Esteves
10// Created On       : Mon May 18 07:44:20 2015
11// Last Modified By : Peter A. Buhr
12// Last Modified On : Mon Jun 29 17:24:39 2015
13// Update Count     : 29
14//
15
16#ifndef LABEL_FIXER_H
17#define LABEL_FIXER_H
18
19#include "utility.h"
20#include "SynTree/SynTree.h"
21#include "SynTree/Visitor.h"
22#include "LabelGenerator.h"
23
24#include <map>
25
26namespace ControlStruct {
27        /// normalizes label definitions and generates multi-level exit labels
28        class LabelFixer : public Visitor {
29                typedef Visitor Parent;
30          public:
31                LabelFixer( LabelGenerator *gen = 0 );
32
33                std::map < Label, Statement * > *resolveJumps() throw ( SemanticError );
34
35                // Declarations
36                virtual void visit( FunctionDecl *functionDecl );
37
38                // Statements
39                void visit( Statement *stmt );
40
41                virtual void visit( CompoundStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
42                virtual void visit( NullStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
43                virtual void visit( ExprStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
44                virtual void visit( IfStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
45                virtual void visit( WhileStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
46                virtual void visit( ForStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
47                virtual void visit( SwitchStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
48                virtual void visit( ChooseStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
49                virtual void visit( FallthruStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
50                virtual void visit( CaseStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
51                virtual void visit( ReturnStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
52                virtual void visit( TryStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
53                virtual void visit( CatchStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
54                virtual void visit( DeclStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
55                virtual void visit( BranchStmt *branchStmt );
56                virtual void visit( UntypedExpr *untyped );
57
58                Label setLabelsDef( std::list< Label > &, Statement *definition );
59                template< typename UsageNode >
60                void setLabelsUsg( Label, UsageNode *usage = 0 );
61
62          private:
63                class Entry {
64                        public:
65                        union UsageLoc {
66                                Statement * stmt;
67                                Expression * expr;
68
69                                void accept( Visitor &visitor );
70                        };
71
72                        Entry( Statement *to ) : definition( to ) {}
73                        Entry( Statement *to, Statement *from );
74                        Entry( Statement *to, Expression *from );
75                        bool used() { return ( usage.empty() ); }
76                        bool defined() { return ( definition != 0 ); }
77                        bool insideLoop();
78
79                        Label get_label() const { return label; }
80                        void set_label( Label lab ) { label = lab; }
81
82                        Statement *get_definition() const { return definition; }
83                        void set_definition( Statement *def ) { definition = def; }
84
85                        std::list< UsageLoc > &get_uses() { return usage; }
86                        void add_use( Statement *use ) {
87                                UsageLoc loc;
88                                loc.stmt = use;
89                                usage.push_back( loc ); 
90                        }
91                        void add_use( Expression *use ) {
92                                UsageLoc loc;
93                                loc.expr = use;
94                                usage.push_back( loc );                                 
95                        }
96
97                        void add_uses ( Entry &other ) { usage.insert( usage.end(), other.usage.begin(), other.usage.end() ); }
98                  private:
99                        Label label; 
100                        Statement *definition;
101                        std::list<UsageLoc> usage;
102                };
103                 
104                std::map < Label, Entry *> labelTable;
105                LabelGenerator *generator;
106                Statement * currentStatement;
107        };
108} // namespace ControlStruct
109
110#endif // LABEL_FIXER_H
111
112// Local Variables: //
113// tab-width: 4 //
114// mode: c++ //
115// compile-command: "make install" //
116// End: //
Note: See TracBrowser for help on using the repository browser.