Changeset 1fbeebd
- Timestamp:
- Nov 30, 2017, 5:37:15 PM (7 years ago)
- Branches:
- ADT, aaron-thesis, arm-eh, ast-experimental, cleanup-dtors, deferred_resn, demangler, enum, forall-pointer-decay, jacob/cs343-translation, jenkins-sandbox, master, new-ast, new-ast-unique-expr, new-env, no_list, persistent-indexer, pthread-emulation, qualifiedEnum, resolv-new, with_gc
- Children:
- ef3d798
- Parents:
- 1cb934d
- git-author:
- Rob Schluntz <rschlunt@…> (11/30/17 17:12:26)
- git-committer:
- Rob Schluntz <rschlunt@…> (11/30/17 17:37:15)
- Location:
- src
- Files:
-
- 4 edited
Legend:
- Unmodified
- Added
- Removed
-
src/ControlStruct/LabelFixer.cc
r1cb934d r1fbeebd 37 37 } 38 38 39 void LabelFixer:: visit( FunctionDecl *functionDecl) {39 void LabelFixer::previsit( FunctionDecl * ) { 40 40 // need to go into a nested function in a fresh state 41 std::map < Label, Entry *> oldLabelTable = labelTable;41 GuardValue( labelTable ); 42 42 labelTable.clear(); 43 } 43 44 44 maybeAccept( functionDecl->get_statements(), *this ); 45 45 void LabelFixer::postvisit( FunctionDecl * functionDecl ) { 46 46 MLEMutator mlemut( resolveJumps(), generator ); 47 47 functionDecl->acceptMutator( mlemut ); 48 49 // and remember the outer function's labels when50 // returning to it51 labelTable = oldLabelTable;52 48 } 53 49 54 50 // prune to at most one label definition for each statement 55 void LabelFixer:: visit( Statement *stmt ) {51 void LabelFixer::previsit( Statement *stmt ) { 56 52 std::list< Label > &labels = stmt->get_labels(); 57 53 … … 62 58 } 63 59 64 void LabelFixer:: visit( BranchStmt *branchStmt ) {65 visit ( ( Statement *)branchStmt );60 void LabelFixer::previsit( BranchStmt *branchStmt ) { 61 previsit( ( Statement *)branchStmt ); 66 62 67 63 // for labeled branches, add an entry to the label table … … 72 68 } 73 69 74 void LabelFixer::visit( UntypedExpr *untyped ) { 75 if ( NameExpr * func = dynamic_cast< NameExpr * >( untyped->get_function() ) ) { 76 if ( func->get_name() == "&&" ) { 77 NameExpr * arg = dynamic_cast< NameExpr * >( untyped->get_args().front() ); 78 Label target = arg->get_name(); 79 assert( target != "" ); 80 setLabelsUsg( target, untyped ); 81 } else { 82 Visitor::visit( untyped ); 83 } 84 } 70 void LabelFixer::previsit( LabelAddressExpr * addrExpr ) { 71 Label & target = addrExpr->arg; 72 assert( target != "" ); 73 setLabelsUsg( target, addrExpr ); 85 74 } 86 75 -
src/ControlStruct/LabelFixer.h
r1cb934d r1fbeebd 19 19 #include <map> // for map 20 20 21 #include "Common/PassVisitor.h" 21 22 #include "Common/SemanticError.h" // for SemanticError 22 23 #include "SynTree/Label.h" // for Label … … 26 27 namespace ControlStruct { 27 28 /// normalizes label definitions and generates multi-level exit labels 28 class LabelGenerator;29 class LabelGenerator; 29 30 30 class LabelFixer final : public Visitor { 31 typedef Visitor Parent; 31 class LabelFixer final : public WithGuards { 32 32 public: 33 33 LabelFixer( LabelGenerator *gen = 0 ); … … 35 35 std::map < Label, Statement * > *resolveJumps() throw ( SemanticError ); 36 36 37 using Visitor::visit;38 39 37 // Declarations 40 virtual void visit( FunctionDecl *functionDecl ) override; 38 void previsit( FunctionDecl *functionDecl ); 39 void postvisit( FunctionDecl *functionDecl ); 41 40 42 41 // Statements 43 void visit( Statement *stmt ); 42 void previsit( Statement *stmt ); 43 void previsit( BranchStmt *branchStmt ); 44 44 45 virtual void visit( CompoundStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 46 virtual void visit( NullStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 47 virtual void visit( ExprStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 48 virtual void visit( IfStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 49 virtual void visit( WhileStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 50 virtual void visit( ForStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 51 virtual void visit( SwitchStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 52 virtual void visit( CaseStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 53 virtual void visit( ReturnStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 54 virtual void visit( TryStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 55 virtual void visit( CatchStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 56 virtual void visit( DeclStmt *stmt ) override { visit( (Statement *)stmt ); return Parent::visit( stmt ); } 57 virtual void visit( BranchStmt *branchStmt ) override; 58 virtual void visit( UntypedExpr *untyped ) override; 45 // Expressions 46 void previsit( LabelAddressExpr *addrExpr ); 59 47 60 48 Label setLabelsDef( std::list< Label > &, Statement *definition ); -
src/ControlStruct/Mutate.cc
r1cb934d r1fbeebd 24 24 #include "SynTree/Declaration.h" // for Declaration 25 25 #include "SynTree/Mutator.h" // for mutateAll 26 //#include "ExceptMutator.h"27 26 28 27 #include "Common/PassVisitor.h" // for PassVisitor … … 37 36 38 37 // normalizes label definitions and generates multi-level exit labels 39 LabelFixer lfix; 40 41 //ExceptMutator exc; 38 PassVisitor<LabelFixer> lfix; 42 39 43 40 mutateAll( translationUnit, formut ); 44 41 acceptAll( translationUnit, lfix ); 45 //mutateAll( translationUnit, exc );46 42 } 47 43 } // namespace CodeGen -
src/InitTweak/InitTweak.cc
r1cb934d r1fbeebd 30 30 namespace InitTweak { 31 31 namespace { 32 class HasDesignations : public WithShortCircuiting { 33 public: 32 struct HasDesignations : public WithShortCircuiting { 34 33 bool hasDesignations = false; 35 34
Note: See TracChangeset
for help on using the changeset viewer.