mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #5270 from ethereum/inlineFlexible
Make full inliner more flexible.
This commit is contained in:
commit
7dffb0f3ee
@ -40,12 +40,9 @@ using namespace dev;
|
||||
using namespace dev::yul;
|
||||
using namespace dev::solidity;
|
||||
|
||||
FullInliner::FullInliner(Block& _ast):
|
||||
m_ast(_ast), m_nameDispenser(_ast)
|
||||
FullInliner::FullInliner(Block& _ast, NameDispenser& _dispenser):
|
||||
m_ast(_ast), m_nameDispenser(_dispenser)
|
||||
{
|
||||
assertThrow(m_ast.statements.size() >= 1, OptimizerException, "");
|
||||
assertThrow(m_ast.statements.front().type() == typeid(Block), OptimizerException, "");
|
||||
|
||||
// Determine constants
|
||||
SSAValueTracker tracker;
|
||||
tracker(m_ast);
|
||||
@ -54,10 +51,11 @@ FullInliner::FullInliner(Block& _ast):
|
||||
m_constants.insert(ssaValue.first);
|
||||
|
||||
map<string, size_t> references = ReferencesCounter::countReferences(m_ast);
|
||||
for (size_t i = 1; i < m_ast.statements.size(); ++i)
|
||||
for (auto& statement: m_ast.statements)
|
||||
{
|
||||
assertThrow(m_ast.statements.at(i).type() == typeid(FunctionDefinition), OptimizerException, "");
|
||||
FunctionDefinition& fun = boost::get<FunctionDefinition>(m_ast.statements.at(i));
|
||||
if (statement.type() != typeid(FunctionDefinition))
|
||||
continue;
|
||||
FunctionDefinition& fun = boost::get<FunctionDefinition>(statement);
|
||||
m_functions[fun.name] = &fun;
|
||||
// Always inline functions that are only called once.
|
||||
if (references[fun.name] == 1)
|
||||
@ -68,9 +66,10 @@ FullInliner::FullInliner(Block& _ast):
|
||||
|
||||
void FullInliner::run()
|
||||
{
|
||||
assertThrow(m_ast.statements[0].type() == typeid(Block), OptimizerException, "");
|
||||
for (auto& statement: m_ast.statements)
|
||||
if (statement.type() == typeid(Block))
|
||||
handleBlock("", boost::get<Block>(statement));
|
||||
|
||||
handleBlock("", boost::get<Block>(m_ast.statements[0]));
|
||||
// TODO it might be good to determine a visiting order:
|
||||
// first handle functions that are called from many places.
|
||||
for (auto const& fun: m_functions)
|
||||
|
@ -71,7 +71,7 @@ class NameCollector;
|
||||
class FullInliner: public ASTModifier
|
||||
{
|
||||
public:
|
||||
explicit FullInliner(Block& _ast);
|
||||
explicit FullInliner(Block& _ast, NameDispenser& _dispenser);
|
||||
|
||||
void run();
|
||||
|
||||
@ -94,7 +94,7 @@ private:
|
||||
/// Variables that are constants (used for inlining heuristic)
|
||||
std::set<std::string> m_constants;
|
||||
std::map<std::string, size_t> m_functionSizes;
|
||||
NameDispenser m_nameDispenser;
|
||||
NameDispenser& m_nameDispenser;
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -131,7 +131,7 @@ bool YulOptimizerTest::run(ostream& _stream, string const& _linePrefix, bool con
|
||||
(FunctionGrouper{})(*m_ast);
|
||||
NameDispenser nameDispenser(*m_ast);
|
||||
ExpressionSplitter{nameDispenser}(*m_ast);
|
||||
FullInliner(*m_ast).run();
|
||||
FullInliner(*m_ast, nameDispenser).run();
|
||||
ExpressionJoiner::run(*m_ast);
|
||||
}
|
||||
else if (m_optimizerStep == "mainFunction")
|
||||
|
Loading…
Reference in New Issue
Block a user