mirror of
				https://github.com/ethereum/solidity
				synced 2023-10-03 13:03:40 +00:00 
			
		
		
		
	Merge pull request #8165 from imapp-pl/yulopti-missing-step
yulopti: Add missing ConditionalUnsimplifier step
This commit is contained in:
		
						commit
						470c19eb8c
					
				| @ -35,6 +35,7 @@ | |||||||
| #include <libyul/optimiser/CallGraphGenerator.h> | #include <libyul/optimiser/CallGraphGenerator.h> | ||||||
| #include <libyul/optimiser/CommonSubexpressionEliminator.h> | #include <libyul/optimiser/CommonSubexpressionEliminator.h> | ||||||
| #include <libyul/optimiser/ConditionalSimplifier.h> | #include <libyul/optimiser/ConditionalSimplifier.h> | ||||||
|  | #include <libyul/optimiser/ConditionalUnsimplifier.h> | ||||||
| #include <libyul/optimiser/ControlFlowSimplifier.h> | #include <libyul/optimiser/ControlFlowSimplifier.h> | ||||||
| #include <libyul/optimiser/NameCollector.h> | #include <libyul/optimiser/NameCollector.h> | ||||||
| #include <libyul/optimiser/EquivalentFunctionCombiner.h> | #include <libyul/optimiser/EquivalentFunctionCombiner.h> | ||||||
| @ -138,12 +139,12 @@ public: | |||||||
| 				m_nameDispenser = make_shared<NameDispenser>(m_dialect, *m_ast, reservedIdentifiers); | 				m_nameDispenser = make_shared<NameDispenser>(m_dialect, *m_ast, reservedIdentifiers); | ||||||
| 				disambiguated = true; | 				disambiguated = true; | ||||||
| 			} | 			} | ||||||
| 			cout << "(q)quit/(f)flatten/(c)se/initialize var(d)ecls/(x)plit/(j)oin/(g)rouper/(h)oister/" << endl; | 			cout << "(q)uit/(f)latten/(c)se/initialize var(d)ecls/(x)plit/(j)oin/(g)rouper/(h)oister/" << endl; | ||||||
| 			cout << "  (e)xpr inline/(i)nline/(s)implify/varname c(l)eaner/(u)nusedprune/ss(a) transform/" << endl; | 			cout << "  (e)xpr inline/(i)nline/(s)implify/varname c(l)eaner/(u)nusedprune/ss(a) transform/" << endl; | ||||||
| 			cout << "  (r)edundant assign elim./re(m)aterializer/f(o)r-loop-init-rewriter/for-loop-condition-(I)nto-body/" << endl; | 			cout << "  (r)edundant assign elim./re(m)aterializer/f(o)r-loop-init-rewriter/for-loop-condition-(I)nto-body/" << endl; | ||||||
| 			cout << "  for-loop-condition-(O)ut-of-body/s(t)ructural simplifier/equi(v)alent function combiner/ssa re(V)erser/" << endl; | 			cout << "  for-loop-condition-(O)ut-of-body/s(t)ructural simplifier/equi(v)alent function combiner/ssa re(V)erser/" << endl; | ||||||
| 			cout << "  co(n)trol flow simplifier/stack com(p)ressor/(D)ead code eliminator/(L)oad resolver/" << endl; | 			cout << "  co(n)trol flow simplifier/stack com(p)ressor/(D)ead code eliminator/(L)oad resolver/" << endl; | ||||||
| 			cout << "  (C)onditional simplifier/loop-invariant code (M)otion?" << endl; | 			cout << "  (C)onditional simplifier/conditional (U)nsimplifier/loop-invariant code (M)otion?" << endl; | ||||||
| 			cout.flush(); | 			cout.flush(); | ||||||
| 			int option = readStandardInputChar(); | 			int option = readStandardInputChar(); | ||||||
| 			cout << ' ' << char(option) << endl; | 			cout << ' ' << char(option) << endl; | ||||||
| @ -171,6 +172,9 @@ public: | |||||||
| 			case 'C': | 			case 'C': | ||||||
| 				ConditionalSimplifier::run(context, *m_ast); | 				ConditionalSimplifier::run(context, *m_ast); | ||||||
| 				break; | 				break; | ||||||
|  | 			case 'U': | ||||||
|  | 				ConditionalUnsimplifier::run(context, *m_ast); | ||||||
|  | 				break; | ||||||
| 			case 'd': | 			case 'd': | ||||||
| 				VarDeclInitializer::run(context, *m_ast); | 				VarDeclInitializer::run(context, *m_ast); | ||||||
| 				break; | 				break; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user