source: src/ControlStruct/LabelFixer.h @ cc79d97

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 cc79d97 was 2871210, checked in by Peter A. Buhr <pabuhr@…>, 9 years ago

include file with keywords, fix type of label address expressions, fix computed goto to any expressions, generic types first attempt

  • Property mode set to 100644
File size: 3.9 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        class LabelFixer : public Visitor {
28                typedef Visitor Parent;
29          public:
30                LabelFixer( LabelGenerator *gen = 0 );
31
32                std::map < Label, Statement * > *resolveJumps() throw ( SemanticError );
33
34                // Declarations
35                virtual void visit( FunctionDecl *functionDecl );
36
37                // Statements
38                void visit( Statement *stmt );
39
40                virtual void visit( CompoundStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
41                virtual void visit( NullStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
42                virtual void visit( ExprStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
43                virtual void visit( IfStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
44                virtual void visit( WhileStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
45                virtual void visit( ForStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
46                virtual void visit( SwitchStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
47                virtual void visit( ChooseStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
48                virtual void visit( FallthruStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
49                virtual void visit( CaseStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
50                virtual void visit( ReturnStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
51                virtual void visit( TryStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
52                virtual void visit( CatchStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
53                virtual void visit( DeclStmt *stmt ) { visit( (Statement *)stmt ); return Parent::visit( stmt ); }
54                virtual void visit( BranchStmt *branchStmt );
55                virtual void visit( UntypedExpr *untyped );
56
57                Label setLabelsDef( std::list< Label > &, Statement *definition );
58                template< typename UsageNode >
59                void setLabelsUsg( Label, UsageNode *usage = 0 );
60
61          private:
62                class Entry {
63                        public:
64                        union UsageLoc {
65                                Statement * stmt;
66                                Expression * expr;
67
68                                void accept( Visitor &visitor );
69                        };
70
71                        Entry( Statement *to ) : definition( to ) {}
72                        Entry( Statement *to, Statement *from );
73                        Entry( Statement *to, Expression *from );
74                        bool used() { return ( usage.empty() ); }
75                        bool defined() { return ( definition != 0 ); }
76                        bool insideLoop();
77
78                        Label get_label() const { return label; }
79                        void set_label( Label lab ) { label = lab; }
80
81                        Statement *get_definition() const { return definition; }
82                        void set_definition( Statement *def ) { definition = def; }
83
84                        std::list< UsageLoc > &get_uses() { return usage; }
85                        void add_use( Statement *use ) {
86                                UsageLoc loc;
87                                loc.stmt = use;
88                                usage.push_back( loc ); 
89                        }
90                        void add_use( Expression *use ) {
91                                UsageLoc loc;
92                                loc.expr = use;
93                                usage.push_back( loc );                                 
94                        }
95
96                        void add_uses ( Entry &other ) { usage.insert( usage.end(), other.usage.begin(), other.usage.end() ); }
97                  private:
98                        Label label; 
99                        Statement *definition;
100                        std::list<UsageLoc> usage;
101                };
102                 
103                std::map < Label, Entry *> labelTable;
104                LabelGenerator *generator;
105                Statement * currentStatement;
106        };
107} // namespace ControlStruct
108
109#endif // LABEL_FIXER_H
110
111// Local Variables: //
112// tab-width: 4 //
113// mode: c++ //
114// compile-command: "make install" //
115// End: //
Note: See TracBrowser for help on using the repository browser.