mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge branch 'develop' of github.com:ethereum/cpp-ethereum into develop
This commit is contained in:
parent
fd1a01bbce
commit
0bcfad54f0
22
Compiler.cpp
22
Compiler.cpp
@ -165,10 +165,26 @@ void Compiler::appendConstructor(FunctionDefinition const& _constructor)
|
|||||||
// copy constructor arguments from code to memory and then to stack, they are supplied after the actual program
|
// copy constructor arguments from code to memory and then to stack, they are supplied after the actual program
|
||||||
if (!_constructor.getParameters().empty())
|
if (!_constructor.getParameters().empty())
|
||||||
{
|
{
|
||||||
|
unsigned argumentSize = 0;
|
||||||
|
for (ASTPointer<VariableDeclaration> const& var: _constructor.getParameters())
|
||||||
|
if (var->getType()->isDynamicallySized())
|
||||||
|
{
|
||||||
|
argumentSize = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
argumentSize += var->getType()->getCalldataEncodedSize();
|
||||||
|
|
||||||
CompilerUtils(m_context).fetchFreeMemoryPointer();
|
CompilerUtils(m_context).fetchFreeMemoryPointer();
|
||||||
m_context.appendProgramSize(); // program itself
|
if (argumentSize == 0)
|
||||||
// CODESIZE is program plus manually added arguments
|
{
|
||||||
m_context << eth::Instruction::CODESIZE << eth::Instruction::SUB;
|
// argument size is dynamic, use CODESIZE to determine it
|
||||||
|
m_context.appendProgramSize(); // program itself
|
||||||
|
// CODESIZE is program plus manually added arguments
|
||||||
|
m_context << eth::Instruction::CODESIZE << eth::Instruction::SUB;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
m_context << u256(argumentSize);
|
||||||
// stack: <memptr> <argument size>
|
// stack: <memptr> <argument size>
|
||||||
m_context << eth::Instruction::DUP1;
|
m_context << eth::Instruction::DUP1;
|
||||||
m_context.appendProgramSize();
|
m_context.appendProgramSize();
|
||||||
|
Loading…
Reference in New Issue
Block a user