diff options
author | Gav Wood <i@gavwood.com> | 2015-06-25 02:15:29 +0800 |
---|---|---|
committer | Gav Wood <i@gavwood.com> | 2015-06-25 02:15:29 +0800 |
commit | 0bcfad54f0464c157bbbadafb522a2d4863a0976 (patch) | |
tree | ca588f8c73fc67bc7c5947f44eb2a79bc301d3e0 /Compiler.cpp | |
parent | fd1a01bbce5b5b6491e05b87fb183a55e9804f4e (diff) | |
download | dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.tar dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.tar.gz dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.tar.bz2 dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.tar.lz dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.tar.xz dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.tar.zst dexon-solidity-0bcfad54f0464c157bbbadafb522a2d4863a0976.zip |
Merge branch 'develop' of github.com:ethereum/cpp-ethereum into develop
Diffstat (limited to 'Compiler.cpp')
-rw-r--r-- | Compiler.cpp | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/Compiler.cpp b/Compiler.cpp index 68052e27..f5570b98 100644 --- a/Compiler.cpp +++ b/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 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(); - m_context.appendProgramSize(); // program itself - // CODESIZE is program plus manually added arguments - m_context << eth::Instruction::CODESIZE << eth::Instruction::SUB; + if (argumentSize == 0) + { + // 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> m_context << eth::Instruction::DUP1; m_context.appendProgramSize(); |