aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity
diff options
context:
space:
mode:
authorchriseth <chris@ethereum.org>2017-12-30 20:47:51 +0800
committerchriseth <chris@ethereum.org>2018-04-12 19:09:37 +0800
commit012ab37fe3984a692dcdda6ef516e4588a8721b3 (patch)
treeedf1f76a47fda1bc5a26076503b0797526c5cf63 /libsolidity
parent8ab7dc036aafd5781118fc16f05df5b0a8a5550e (diff)
downloaddexon-solidity-012ab37fe3984a692dcdda6ef516e4588a8721b3.tar.gz
dexon-solidity-012ab37fe3984a692dcdda6ef516e4588a8721b3.tar.zst
dexon-solidity-012ab37fe3984a692dcdda6ef516e4588a8721b3.zip
Code generator for revert with reason string.
Diffstat (limited to 'libsolidity')
-rw-r--r--libsolidity/codegen/ExpressionCompiler.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/libsolidity/codegen/ExpressionCompiler.cpp b/libsolidity/codegen/ExpressionCompiler.cpp
index 57d49ac6..dc9fae21 100644
--- a/libsolidity/codegen/ExpressionCompiler.cpp
+++ b/libsolidity/codegen/ExpressionCompiler.cpp
@@ -680,8 +680,25 @@ bool ExpressionCompiler::visit(FunctionCall const& _functionCall)
m_context << Instruction::SELFDESTRUCT;
break;
case FunctionType::Kind::Revert:
- m_context.appendRevert();
+ {
+ if (!arguments.empty())
+ {
+ solAssert(arguments.size() == 1, "");
+ solAssert(function.parameterTypes().size() == 1, "");
+ m_context << u256(0);
+ arguments.front()->accept(*this);
+ utils().fetchFreeMemoryPointer();
+ utils().abiEncode(
+ {make_shared<IntegerType>(256), arguments.front()->annotation().type},
+ {make_shared<IntegerType>(256), make_shared<ArrayType>(DataLocation::Memory, true)}
+ );
+ utils().toSizeAfterFreeMemoryPointer();
+ m_context << Instruction::REVERT;
+ }
+ else
+ m_context.appendRevert();
break;
+ }
case FunctionType::Kind::SHA3:
{
TypePointers argumentTypes;