mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #2375 from ethereum/macro_with_zero_args
LLL: macro with zero args
This commit is contained in:
commit
0c8c209194
@ -109,7 +109,7 @@ void dev::eth::parseTreeLLL(string const& _s, sp::utree& o_out)
|
|||||||
qi::rule<it, space_type, sp::utree::list_type()> mstore = '[' > element > ']' > -qi::lit(":") > element;
|
qi::rule<it, space_type, sp::utree::list_type()> mstore = '[' > element > ']' > -qi::lit(":") > element;
|
||||||
qi::rule<it, space_type, sp::utree::list_type()> sstore = qi::lit("[[") > element > qi::lit("]]") > -qi::lit(":") > element;
|
qi::rule<it, space_type, sp::utree::list_type()> sstore = qi::lit("[[") > element > qi::lit("]]") > -qi::lit(":") > element;
|
||||||
qi::rule<it, space_type, sp::utree::list_type()> calldataload = qi::lit("$") > element;
|
qi::rule<it, space_type, sp::utree::list_type()> calldataload = qi::lit("$") > element;
|
||||||
qi::rule<it, space_type, sp::utree::list_type()> list = '(' > +element > ')';
|
qi::rule<it, space_type, sp::utree::list_type()> list = '(' > *element > ')';
|
||||||
|
|
||||||
qi::rule<it, space_type, sp::utree()> extra = sload[tagNode<2>()] | mload[tagNode<1>()] | sstore[tagNode<4>()] | mstore[tagNode<3>()] | seq[tagNode<5>()] | calldataload[tagNode<6>()];
|
qi::rule<it, space_type, sp::utree()> extra = sload[tagNode<2>()] | mload[tagNode<1>()] | sstore[tagNode<4>()] | mstore[tagNode<3>()] | seq[tagNode<5>()] | calldataload[tagNode<6>()];
|
||||||
element = atom | list | extra;
|
element = atom | list | extra;
|
||||||
|
@ -279,6 +279,18 @@ BOOST_AUTO_TEST_CASE(assembly_codecopy)
|
|||||||
BOOST_CHECK(callFallback() == encodeArgs(string("abcdef")));
|
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_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -171,7 +171,13 @@ BOOST_AUTO_TEST_CASE(list)
|
|||||||
BOOST_CHECK_EQUAL(parse(text), R"(( 1234 ))");
|
BOOST_CHECK_EQUAL(parse(text), R"(( 1234 ))");
|
||||||
|
|
||||||
BOOST_CHECK(successParse("( 1234 5467 )"));
|
BOOST_CHECK(successParse("( 1234 5467 )"));
|
||||||
BOOST_CHECK(!successParse("()"));
|
BOOST_CHECK(successParse("()"));
|
||||||
|
}
|
||||||
|
|
||||||
|
BOOST_AUTO_TEST_CASE(macro_with_zero_args)
|
||||||
|
{
|
||||||
|
char const* text = "(def 'zeroargs () (asm INVALID))";
|
||||||
|
BOOST_CHECK(successParse(text));
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_SUITE_END()
|
BOOST_AUTO_TEST_SUITE_END()
|
||||||
|
Loading…
Reference in New Issue
Block a user