source: src/ControlStruct/LabelFixer.h@ 71bd8c6

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 71bd8c6 was 2871210, checked in by Peter A. Buhr <pabuhr@…>, 10 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.