Unifies behavior for member access of ABI functions.

This commit is contained in:
Erik Kundt 2019-04-29 14:27:10 +02:00
parent 1eeca84cad
commit 381ed5a302
3 changed files with 19 additions and 1 deletions

View File

@ -1401,7 +1401,7 @@ bool ExpressionCompiler::visit(MemberAccess const& _memberAccess)
m_context << Instruction::DUP1 << u256(32) << Instruction::ADD; m_context << Instruction::DUP1 << u256(32) << Instruction::ADD;
utils().storeStringData(contract.name()); utils().storeStringData(contract.name());
} }
else if (member == "encode" || member == "decode") else if ((set<string>{"encode", "encodePacked", "encodeWithSelector", "encodeWithSignature", "decode"}).count(member))
{ {
// no-op // no-op
} }

View File

@ -1,6 +1,9 @@
contract C { contract C {
function f() public pure { function f() public pure {
abi.encode; abi.encode;
abi.encodePacked;
abi.encodeWithSelector;
abi.encodeWithSignature;
abi.decode; abi.decode;
} }
} }

View File

@ -0,0 +1,15 @@
contract C {
function f() public pure {
abi.encode;
abi.encodePacked;
abi.encodeWithSelector;
abi.encodeWithSignature;
abi.decode;
}
}
// ----
// Warning: (52-62): Statement has no effect.
// Warning: (72-88): Statement has no effect.
// Warning: (98-120): Statement has no effect.
// Warning: (130-153): Statement has no effect.
// Warning: (163-173): Statement has no effect.