source: src/ControlStruct/MLEMutator.h @ f8a8fb1

ADTarm-ehast-experimentalenumforall-pointer-decayjacob/cs343-translationnew-ast-unique-exprpthread-emulationqualifiedEnum
Last change on this file since f8a8fb1 was 9bdb8b7, checked in by Peter A. Buhr <pabuhr@…>, 5 years ago

allow labelled break from within the body of a try statement

  • Property mode set to 100644
File size: 4.6 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//
[0f8e4ac]7// MLEMutator.h --
[51587aa]8//
[843054c2]9// Author           : Rodolfo G. Esteves
[51587aa]10// Created On       : Mon May 18 07:44:20 2015
[adcc065]11// Last Modified By : Peter A. Buhr
[9bdb8b7]12// Last Modified On : Tue Oct 22 17:22:47 2019
13// Update Count     : 45
[51587aa]14//
[a08ba92]15
[6b0b624]16#pragma once
[51b7345]17
[d180746]18#include <list>                    // for list
19#include <map>                     // for map
20#include <string>                  // for string
[720a007]21#include <set>                     // for unordered_set
[51b7345]22
[94e025a2]23#include "Common/PassVisitor.h"
[d180746]24#include "Common/SemanticError.h"  // for SemanticError
25#include "SynTree/Label.h"         // for Label
26#include "SynTree/Mutator.h"       // for Mutator
27#include "SynTree/SynTree.h"       // for Visitor Nodes
[51b7345]28
29namespace ControlStruct {
[94e025a2]30        class LabelGenerator;
[d180746]31
[720a007]32        class MLEMutator : public WithVisitorRef<MLEMutator>, public WithShortCircuiting, public WithGuards {
[d9a0e76]33          public:
[720a007]34                class Entry;
[a08ba92]35                MLEMutator( std::map<Label, Statement *> *t, LabelGenerator *gen = 0 ) : targetTable( t ), breakLabel(std::string("")), generator( gen ) {}
36                ~MLEMutator();
[d9a0e76]37
[94e025a2]38                void premutate( CompoundStmt *cmpndStmt );
[a16764a6]39                Statement * postmutate( BranchStmt *branchStmt ) throw ( SemanticErrorException );
[94e025a2]40                void premutate( WhileStmt *whileStmt );
41                Statement * postmutate( WhileStmt *whileStmt );
42                void premutate( ForStmt *forStmt );
43                Statement * postmutate( ForStmt *forStmt );
44                void premutate( CaseStmt *caseStmt );
45                void premutate( IfStmt *ifStmt );
46                Statement * postmutate( IfStmt *ifStmt );
47                void premutate( SwitchStmt *switchStmt );
48                Statement * postmutate( SwitchStmt *switchStmt );
[9bdb8b7]49                void premutate( TryStmt *tryStmt );
50                Statement * postmutate( TryStmt *tryStmt );
[d9a0e76]51
[a08ba92]52                Statement *mutateLoop( Statement *bodyLoop, Entry &e );
[d9a0e76]53
[a08ba92]54                Label &get_breakLabel() { return breakLabel; }
55                void set_breakLabel( Label newValue ) { breakLabel = newValue; }
[720a007]56
[a08ba92]57                class Entry {
58                  public:
[720a007]59                        // specialized constructors for each combination of statement with labelled break/continue/fallthrough that is valid to cleanup the use cases
60                        explicit Entry( ForStmt *stmt, Label breakExit, Label contExit ) :
61                                stmt( stmt ), breakExit( breakExit ), contExit( contExit ) {}
62
63                        explicit Entry( WhileStmt *stmt, Label breakExit, Label contExit ) :
64                                stmt( stmt ), breakExit( breakExit ), contExit( contExit ) {}
[d9a0e76]65
[720a007]66                        explicit Entry( CompoundStmt *stmt, Label breakExit ) :
67                                stmt( stmt ), breakExit( breakExit ) {}
[d9a0e76]68
[720a007]69                        explicit Entry( IfStmt *stmt, Label breakExit ) :
70                                stmt( stmt ), breakExit( breakExit ) {}
[d9a0e76]71
[720a007]72                        explicit Entry( CaseStmt *stmt, Label fallExit ) :
73                                stmt( stmt ), fallExit( fallExit ) {}
74
75                        explicit Entry( SwitchStmt *stmt, Label breakExit, Label fallDefaultExit ) :
76                                stmt( stmt ), breakExit( breakExit ), fallDefaultExit( fallDefaultExit ) {}
77
[9bdb8b7]78                        explicit Entry( TryStmt *stmt, Label breakExit ) :
79                                stmt( stmt ), breakExit( breakExit ) {}
80
[720a007]81                        bool operator==( const Statement *other ) { return stmt == other; }
82                        bool operator!=( const Statement *other ) { return stmt != other; }
83
84                        bool operator==( const Entry &other ) { return stmt == other.get_controlStructure(); }
85
86                        Statement *get_controlStructure() const { return stmt; }
[51b7345]87
[27de955]88                        Label useContExit() { contUsed = true; return contExit; }
89                        Label useBreakExit() { breakUsed = true; return breakExit; }
[720a007]90                        Label useFallExit() { fallUsed = true; return fallExit; }
91                        Label useFallDefaultExit() { fallDefaultUsed = true; return fallDefaultExit; }
[a08ba92]92
[27de955]93                        bool isContUsed() const { return contUsed; }
94                        bool isBreakUsed() const { return breakUsed; }
[720a007]95                        bool isFallUsed() const { return fallUsed; }
96                        bool isFallDefaultUsed() const { return fallDefaultUsed; }
97                        void seenDefault() { fallDefaultValid = false; }
98                        bool isFallDefaultValid() const { return fallDefaultValid; }
[a08ba92]99                  private:
[720a007]100                        Statement *stmt;
101                        Label breakExit, contExit, fallExit, fallDefaultExit;
102                        bool breakUsed = false, contUsed = false, fallUsed = false, fallDefaultUsed = false;
103                        bool fallDefaultValid = true;
[a08ba92]104                };
105
[720a007]106          private:
[a08ba92]107                std::map< Label, Statement * > *targetTable;
[720a007]108                std::set< Label > fallthroughLabels;
[e39aa0f]109                std::list< Entry > enclosingControlStructures;
[a08ba92]110                Label breakLabel;
111                LabelGenerator *generator;
[be5aa1b]112
[27de955]113                template< typename LoopClass >
[94e025a2]114                void prehandleLoopStmt( LoopClass * loopStmt );
[27de955]115
[94e025a2]116                template< typename LoopClass >
117                Statement * posthandleLoopStmt( LoopClass * loopStmt );
[27de955]118
[720a007]119                void fixBlock( std::list< Statement * > &kids, bool caseClause = false );
[a08ba92]120        };
[51b7345]121} // namespace ControlStruct
122
[51587aa]123// Local Variables: //
124// tab-width: 4 //
125// mode: c++ //
126// compile-command: "make install" //
127// End: //
Note: See TracBrowser for help on using the repository browser.