Merge pull request #10960 from ethereum/ir-constructor-argument-multiple-slot

[sol2yul] IR constructor argument multiple slot
This commit is contained in:
chriseth 2021-02-15 14:59:02 +01:00 committed by GitHub
commit f81568f684
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 32 additions and 2 deletions

View File

@ -4255,7 +4255,7 @@ string YulUtilFunctions::copyConstructorArgumentsToMemoryFunction(
toString(_contract.id()); toString(_contract.id());
return m_functionCollector.createFunction(functionName, [&]() { return m_functionCollector.createFunction(functionName, [&]() {
string returnParams = suffixedVariableNameList("ret_param_",0, _contract.constructor()->parameters().size()); string returnParams = suffixedVariableNameList("ret_param_",0, CompilerUtils::sizeOnStack(_contract.constructor()->parameters()));
ABIFunctions abiFunctions(m_evmVersion, m_revertStrings, m_functionCollector); ABIFunctions abiFunctions(m_evmVersion, m_revertStrings, m_functionCollector);
return util::Whiskers(R"( return util::Whiskers(R"(

View File

@ -129,7 +129,7 @@ string IRGenerator::generate(
vector<string> constructorParams; vector<string> constructorParams;
if (constructor && !constructor->parameters().empty()) if (constructor && !constructor->parameters().empty())
{ {
for (size_t i = 0; i < constructor->parameters().size(); ++i) for (size_t i = 0; i < CompilerUtils::sizeOnStack(constructor->parameters()); ++i)
constructorParams.emplace_back(m_context.newYulVariable()); constructorParams.emplace_back(m_context.newYulVariable());
t( t(
"copyConstructorArguments", "copyConstructorArguments",

View File

@ -0,0 +1,9 @@
// The IR of this test used to throw
contract D {
constructor(function() external returns (uint)) {
}
}
// ====
// compileViaYul: also
// ----
// constructor(): 0xfdd67305928fcac8d213d1e47bfa6165cd0b87b946644cd0000000000000000 ->

View File

@ -0,0 +1,21 @@
contract D {
uint public x;
constructor(function() external pure returns (uint) g) {
x = g();
}
}
contract C {
function f() public returns (uint r) {
D d = new D(this.sixteen);
r = d.x();
}
function sixteen() public pure returns (uint) {
return 16;
}
}
// ====
// compileViaYul: also
// ----
// f() -> 16