source: src/ControlStruct/LabelFixer.h@ cff1143

ADT aaron-thesis arm-eh ast-experimental cleanup-dtors ctor deferred_resn demangler enum forall-pointer-decay gc_noraii jacob/cs343-translation jenkins-sandbox memory new-ast new-ast-unique-expr new-env no_list persistent-indexer pthread-emulation qualifiedEnum resolv-new string with_gc
Last change on this file since cff1143 was 82dd287, checked in by Aaron Moss <a3moss@…>, 10 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.