From d5cd02b8edb06699b1cc6c37e69694870a4c21dc Mon Sep 17 00:00:00 2001 From: chriseth Date: Tue, 25 Sep 2018 16:29:08 +0200 Subject: [PATCH] Fix for inlining inside conditions. --- libjulia/optimiser/FullInliner.cpp | 5 +++ test/libjulia/Inliner.cpp | 60 +++++++++++++++--------------- 2 files changed, 35 insertions(+), 30 deletions(-) diff --git a/libjulia/optimiser/FullInliner.cpp b/libjulia/optimiser/FullInliner.cpp index e8776e234..f41dc198c 100644 --- a/libjulia/optimiser/FullInliner.cpp +++ b/libjulia/optimiser/FullInliner.cpp @@ -89,6 +89,9 @@ void InlineModifier::operator()(ForLoop& _loop) void InlineModifier::operator()(Block& _block) { + vector saved; + saved.swap(m_statementsToPrefix); + // This is only used if needed to minimize the number of move operations. vector modifiedStatements; for (size_t i = 0; i < _block.statements.size(); ++i) @@ -110,6 +113,8 @@ void InlineModifier::operator()(Block& _block) } if (!modifiedStatements.empty()) _block.statements = std::move(modifiedStatements); + + saved.swap(m_statementsToPrefix); } void InlineModifier::visit(Expression& _expression) diff --git a/test/libjulia/Inliner.cpp b/test/libjulia/Inliner.cpp index 0cffabb29..d0ecd42fa 100644 --- a/test/libjulia/Inliner.cpp +++ b/test/libjulia/Inliner.cpp @@ -344,37 +344,37 @@ BOOST_AUTO_TEST_CASE(pop_result) BOOST_AUTO_TEST_CASE(inside_condition) { - // This tests that breaking the expresison inside the condition works properly. + // This tests that breaking the expression inside the condition works properly. BOOST_CHECK_EQUAL( - fullInline(R"({ - if gt(f(mload(1)), mload(0)) { - sstore(0, 2) - } - function f(a) -> r { - a := mload(a) - r := add(a, calldatasize()) - } - })", false), - format(R"({ - { - let _1 := mload(0) - let f_a := mload(1) - let f_r - { - f_a := mload(f_a) - f_r := add(f_a, calldatasize()) - } - if gt(f_r, _1) - { - sstore(0, 2) - } - } - function f(a) -> r - { - a := mload(a) - r := add(a, calldatasize()) - } - })", false) + fullInline("{" + "if gt(f(mload(1)), mload(0)) {" + "sstore(0, 2)" + "}" + "function f(a) -> r {" + "a := mload(a)" + "r := add(a, calldatasize())" + "}" + "}", false), + format("{" + "{" + "let _1 := mload(0)" + "let f_a := mload(1)" + "let f_r" + "{" + "f_a := mload(f_a)" + "f_r := add(f_a, calldatasize())" + "}" + "if gt(f_r, _1)" + "{" + "sstore(0, 2)" + "}" + "}" + "function f(a) -> r" + "{" + "a := mload(a)" + "r := add(a, calldatasize())" + "}" + "}", false) ); }