source: src/ControlStruct/LabelFixer.h @ b29f8f3

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 b29f8f3 was 82dd287, checked in by Aaron Moss <a3moss@…>, 9 years ago

Doc comments

  • Property mode set to 100644
File size: 4.0 KB
RevLine 
[51587aa]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//
[a08ba92]7// LabelFixer.h --
[51587aa]8//
[843054c2]9// Author           : Rodolfo G. Esteves
[51587aa]10// Created On       : Mon May 18 07:44:20 2015
[2871210]11// Last Modified By : Peter A. Buhr
12// Last Modified On : Mon Jun 29 17:24:39 2015
13// Update Count     : 29
[51587aa]14//
[a08ba92]15
[51b7345]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 {
[82dd287]27        /// normalizes label definitions and generates multi-level exit labels
[a08ba92]28        class LabelFixer : public Visitor {
29                typedef Visitor Parent;
[d9a0e76]30          public:
[a08ba92]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 );
[1869adf]56                virtual void visit( UntypedExpr *untyped );
[a08ba92]57
58                Label setLabelsDef( std::list< Label > &, Statement *definition );
[1869adf]59                template< typename UsageNode >
60                void setLabelsUsg( Label, UsageNode *usage = 0 );
[d9a0e76]61
62          private:
[a08ba92]63                class Entry {
[1869adf]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 );
[a08ba92]75                        bool used() { return ( usage.empty() ); }
76                        bool defined() { return ( definition != 0 ); }
77                        bool insideLoop();
78
79                        Label get_label() const { return label; }
[be5aa1b]80                        void set_label( Label lab ) { label = lab; }
81
[a08ba92]82                        Statement *get_definition() const { return definition; }
[be5aa1b]83                        void set_definition( Statement *def ) { definition = def; }
[a08ba92]84
[1869adf]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
[2871210]97                        void add_uses ( Entry &other ) { usage.insert( usage.end(), other.usage.begin(), other.usage.end() ); }
[a08ba92]98                  private:
99                        Label label; 
100                        Statement *definition;
[1869adf]101                        std::list<UsageLoc> usage;
[a08ba92]102                };
103                 
104                std::map < Label, Entry *> labelTable;
105                LabelGenerator *generator;
[1869adf]106                Statement * currentStatement;
[d9a0e76]107        };
[51b7345]108} // namespace ControlStruct
109
[d9a0e76]110#endif // LABEL_FIXER_H
[51b7345]111
[51587aa]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.