/* This file is part of solidity. solidity is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. solidity is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with solidity. If not, see . */ #pragma once #include #include #include namespace yul { /** * Structural simplifier. Performs the following simplification steps: * - replace if with empty body with pop(condition) * - replace if with true condition with its body * - remove if with false condition * - remove empty default switch case * - remove empty switch case if no default case exists * - replace switch with no cases with pop(expression) * - turn switch with single case into if * - replace switch with only default case with pop(expression) and body * - replace switch with const expr with matching case body * - replace for with false condition by its initialization part * * Prerequisite: Disambiguator, ForLoopInitRewriter. * * Important: Can only be used on EVM code. */ class StructuralSimplifier: public DataFlowAnalyzer { public: explicit StructuralSimplifier(Dialect const& _dialect): DataFlowAnalyzer(_dialect) {} using DataFlowAnalyzer::operator(); void operator()(Block& _block) override; private: void simplify(std::vector& _statements); bool expressionAlwaysTrue(Expression const& _expression); bool expressionAlwaysFalse(Expression const& _expression); boost::optional hasLiteralValue(Expression const& _expression) const; boost::optional> reduceNoCaseSwitch(Switch& _switchStmt) const; }; }