diff options
author | chriseth <chris@ethereum.org> | 2017-06-28 22:32:43 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-06-28 22:32:43 +0800 |
commit | 79d13366874c432c2f8f2adf3cd8cc00638c6a98 (patch) | |
tree | a488a397a44cb38e929657831a0f415d6f1b09bc | |
parent | e19c4125af62c4f02e476664791f8b091a467902 (diff) | |
parent | dbbdcc66e61a5a5d36a4fd55087b22e145a1c3e4 (diff) | |
download | dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.tar dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.tar.gz dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.tar.bz2 dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.tar.lz dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.tar.xz dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.tar.zst dexon-solidity-79d13366874c432c2f8f2adf3cd8cc00638c6a98.zip |
Merge pull request #2462 from ethereum/lll-fix-def
LLL: fix redefinitions on some compilers
-rw-r--r-- | liblll/CodeFragment.cpp | 6 | ||||
-rw-r--r-- | test/liblll/EndToEndTest.cpp | 37 |
2 files changed, 31 insertions, 12 deletions
diff --git a/liblll/CodeFragment.cpp b/liblll/CodeFragment.cpp index 7496fe83..56c1e26a 100644 --- a/liblll/CodeFragment.cpp +++ b/liblll/CodeFragment.cpp @@ -258,7 +258,11 @@ void CodeFragment::constructOperation(sp::utree const& _t, CompilerState& _s) } else if (ii == 2) if (_t.size() == 3) - _s.defs[n] = CodeFragment(i, _s); + { + /// NOTE: some compilers could do the assignment first if this is done in a single line + CodeFragment code = CodeFragment(i, _s); + _s.defs[n] = code; + } else for (auto const& j: i) { diff --git a/test/liblll/EndToEndTest.cpp b/test/liblll/EndToEndTest.cpp index 3037b14b..70a91807 100644 --- a/test/liblll/EndToEndTest.cpp +++ b/test/liblll/EndToEndTest.cpp @@ -57,6 +57,32 @@ BOOST_AUTO_TEST_CASE(panic) BOOST_REQUIRE(m_output.empty()); } +BOOST_AUTO_TEST_CASE(macro_zeroarg) +{ + char const* sourceCode = R"( + (returnlll + (seq + (def 'zeroarg () (seq (mstore 0 0x1234) (return 0 32))) + (zeroarg))) + )"; + compileAndRun(sourceCode); + BOOST_CHECK(callFallback() == encodeArgs(u256(0x1234))); +} + +BOOST_AUTO_TEST_CASE(macros) +{ + char const* sourceCode = R"( + (returnlll + (seq + (def 'x 1) + (def 'y () { (def 'x (+ x 2)) }) + (y) + (return x))) + )"; + compileAndRun(sourceCode); + BOOST_CHECK(callFallback() == encodeArgs(u256(3))); +} + BOOST_AUTO_TEST_CASE(variables) { char const* sourceCode = R"( @@ -361,17 +387,6 @@ BOOST_AUTO_TEST_CASE(assembly_codecopy) BOOST_CHECK(callFallback() == encodeArgs(string("abcdef"))); } -BOOST_AUTO_TEST_CASE(zeroarg_macro) -{ - char const* sourceCode = R"( - (returnlll - (seq - (def 'zeroarg () (seq (mstore 0 0x1234) (return 0 32))) - (zeroarg))) - )"; - compileAndRun(sourceCode); - BOOST_CHECK(callFallback() == encodeArgs(u256(0x1234))); -} BOOST_AUTO_TEST_CASE(keccak256_32bytes) { |