aboutsummaryrefslogtreecommitdiffstats
path: root/test/libsolidity/SolidityOptimizer.cpp
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2018-04-04 20:37:43 +0800
committerGitHub <noreply@github.com>2018-04-04 20:37:43 +0800
commit2fe5607a5a6618f27f4ed5c1effb4273c662ee3a (patch)
treeaef8f1dc5fa400e27ea5072f10c64f7ec5374b22 /test/libsolidity/SolidityOptimizer.cpp
parentc5c5b23ff485075836b0b80db6e7cfebf0eebb4b (diff)
parent0cbe55005de79b0f7c5c770d50c3eb87df019789 (diff)
downloaddexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar
dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.gz
dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.bz2
dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.lz
dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.xz
dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.tar.zst
dexon-solidity-2fe5607a5a6618f27f4ed5c1effb4273c662ee3a.zip
Merge pull request #3721 from ethereum/simpleDynArray
Create empty dynamic memory arrays more efficiently.
Diffstat (limited to 'test/libsolidity/SolidityOptimizer.cpp')
-rw-r--r--test/libsolidity/SolidityOptimizer.cpp24
1 files changed, 24 insertions, 0 deletions
diff --git a/test/libsolidity/SolidityOptimizer.cpp b/test/libsolidity/SolidityOptimizer.cpp
index cf4550c7..a0df76f3 100644
--- a/test/libsolidity/SolidityOptimizer.cpp
+++ b/test/libsolidity/SolidityOptimizer.cpp
@@ -93,8 +93,10 @@ public:
{
m_contractAddress = m_nonOptimizedContract;
bytes nonOptimizedOutput = callContractFunction(_sig, _arguments...);
+ m_gasUsedNonOptimized = m_gasUsed;
m_contractAddress = m_optimizedContract;
bytes optimizedOutput = callContractFunction(_sig, _arguments...);
+ m_gasUsedOptimized = m_gasUsed;
BOOST_CHECK_MESSAGE(!optimizedOutput.empty(), "No optimized output for " + _sig);
BOOST_CHECK_MESSAGE(!nonOptimizedOutput.empty(), "No un-optimized output for " + _sig);
BOOST_CHECK_MESSAGE(nonOptimizedOutput == optimizedOutput, "Computed values do not match."
@@ -120,6 +122,8 @@ public:
}
protected:
+ u256 m_gasUsedOptimized;
+ u256 m_gasUsedNonOptimized;
bytes m_nonOptimizedBytecode;
bytes m_optimizedBytecode;
Address m_optimizedContract;
@@ -584,6 +588,26 @@ BOOST_AUTO_TEST_CASE(invalid_state_at_control_flow_join)
compareVersions("test()");
}
+BOOST_AUTO_TEST_CASE(init_empty_dynamic_arrays)
+{
+ // This is not so much an optimizer test, but rather a test
+ // that allocating empty arrays is implemented efficiently.
+ // In particular, initializing a dynamic memory array does
+ // not use any memory.
+ char const* sourceCode = R"(
+ contract Test {
+ function f() pure returns (uint r) {
+ uint[][] memory x = new uint[][](20000);
+ return x.length;
+ }
+ }
+ )";
+ compileBothVersions(sourceCode);
+ compareVersions("f()");
+ BOOST_CHECK_LE(m_gasUsedNonOptimized, 1900000);
+ BOOST_CHECK_LE(1600000, m_gasUsedNonOptimized);
+}
+
BOOST_AUTO_TEST_CASE(optimise_multi_stores)
{
char const* sourceCode = R"(