Merge pull request #6029 from ethereum/fixDelegatecallV2

Fix combination of delegatecall and ABIEncoderV2.
This commit is contained in:
chriseth 2019-02-19 14:16:09 +01:00 committed by GitHub
commit 8607690a30
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 26 additions and 18 deletions

View File

@ -8,6 +8,7 @@ Compiler Features:
Bugfixes: Bugfixes:
* ABIEncoderV2: Fix internal error related to bare delegatecall.
* ABIEncoderV2: Fix internal error related to mappings as library parameters. * ABIEncoderV2: Fix internal error related to mappings as library parameters.
* Yul: Properly detect name clashes with functions before their declaration. * Yul: Properly detect name clashes with functions before their declaration.

View File

@ -1967,12 +1967,13 @@ void ExpressionCompiler::appendExternalFunctionCall(
// If the function takes arbitrary parameters or is a bare call, copy dynamic length data in place. // If the function takes arbitrary parameters or is a bare call, copy dynamic length data in place.
// Move arguments to memory, will not update the free memory pointer (but will update the memory // Move arguments to memory, will not update the free memory pointer (but will update the memory
// pointer on the stack). // pointer on the stack).
bool encodeForLibraryCall = funKind == FunctionType::Kind::DelegateCall;
utils().encodeToMemory( utils().encodeToMemory(
argumentTypes, argumentTypes,
parameterTypes, parameterTypes,
_functionType.padArguments(), _functionType.padArguments(),
_functionType.takesArbitraryParameters() || _functionType.isBareCall(), _functionType.takesArbitraryParameters() || _functionType.isBareCall(),
isDelegateCall encodeForLibraryCall
); );
// Stack now: // Stack now:

View File

@ -4440,9 +4440,14 @@ BOOST_AUTO_TEST_CASE(generic_delegatecall)
} }
} }
)**"; )**";
compileAndRun(sourceCode, 0, "Receiver");
for (auto v2: {false, true})
{
string source = (v2 ? "pragma experimental ABIEncoderV2;\n" : "") + string(sourceCode);
compileAndRun(source, 0, "Receiver");
u160 const c_receiverAddress = m_contractAddress; u160 const c_receiverAddress = m_contractAddress;
compileAndRun(sourceCode, 50, "Sender"); compileAndRun(source, 50, "Sender");
u160 const c_senderAddress = m_contractAddress; u160 const c_senderAddress = m_contractAddress;
BOOST_CHECK(m_sender != c_senderAddress); // just for sanity BOOST_CHECK(m_sender != c_senderAddress); // just for sanity
ABI_CHECK(callContractFunctionWithValue("doSend(address)", 11, c_receiverAddress), encodeArgs()); ABI_CHECK(callContractFunctionWithValue("doSend(address)", 11, c_receiverAddress), encodeArgs());
@ -4457,6 +4462,7 @@ BOOST_AUTO_TEST_CASE(generic_delegatecall)
BOOST_CHECK(!storageEmpty(c_senderAddress)); BOOST_CHECK(!storageEmpty(c_senderAddress));
BOOST_CHECK_EQUAL(balanceAt(c_receiverAddress), 0); BOOST_CHECK_EQUAL(balanceAt(c_receiverAddress), 0);
BOOST_CHECK_EQUAL(balanceAt(c_senderAddress), 50 + 11); BOOST_CHECK_EQUAL(balanceAt(c_senderAddress), 50 + 11);
}
} }
BOOST_AUTO_TEST_CASE(generic_staticcall) BOOST_AUTO_TEST_CASE(generic_staticcall)