Skip to content

Commit

Permalink
Merge pull request ethereum#2375 from ethereum/macro_with_zero_args
Browse files Browse the repository at this point in the history
LLL: macro with zero args
  • Loading branch information
axic committed Jun 13, 2017
2 parents 3699d27 + c4f0608 commit 0c8c209
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 2 deletions.
2 changes: 1 addition & 1 deletion liblll/Parser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -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()> 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()> 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>()];
element = atom | list | extra;
Expand Down
12 changes: 12 additions & 0 deletions test/liblll/EndToEndTest.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -279,6 +279,18 @@ 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_SUITE_END()

}
Expand Down
8 changes: 7 additions & 1 deletion test/liblll/Parser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,13 @@ BOOST_AUTO_TEST_CASE(list)
BOOST_CHECK_EQUAL(parse(text), R"(( 1234 ))");

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()
Expand Down

0 comments on commit 0c8c209

Please sign in to comment.