aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/codegen/CompilerUtils.cpp
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2016-12-01 20:12:10 +0800
committerAlex Beregszaszi <alex@rtfs.hu>2017-02-01 20:23:47 +0800
commit767ec1d670808cd479ac74780bff51a1f1900f04 (patch)
treecd4ff439885a636907be37d63ce0fb5bacae8913 /libsolidity/codegen/CompilerUtils.cpp
parentc1a675da4f01728784c9b7e1d82665bb8dfbcc99 (diff)
downloaddexon-solidity-767ec1d670808cd479ac74780bff51a1f1900f04.tar.gz
dexon-solidity-767ec1d670808cd479ac74780bff51a1f1900f04.tar.zst
dexon-solidity-767ec1d670808cd479ac74780bff51a1f1900f04.zip
Support explicit conversion of external function type to address
Diffstat (limited to 'libsolidity/codegen/CompilerUtils.cpp')
-rw-r--r--libsolidity/codegen/CompilerUtils.cpp12
1 files changed, 12 insertions, 0 deletions
diff --git a/libsolidity/codegen/CompilerUtils.cpp b/libsolidity/codegen/CompilerUtils.cpp
index 477f021a..469bd0ed 100644
--- a/libsolidity/codegen/CompilerUtils.cpp
+++ b/libsolidity/codegen/CompilerUtils.cpp
@@ -787,6 +787,18 @@ void CompilerUtils::convertType(Type const& _typeOnStack, Type const& _targetTyp
if (_cleanupNeeded)
m_context << Instruction::ISZERO << Instruction::ISZERO;
break;
+ case Type::Category::Function:
+ {
+ solAssert(targetTypeCategory == Type::Category::Integer, "Invalid conversion for function type.");
+ IntegerType const& targetType = dynamic_cast<IntegerType const&>(_targetType);
+ solAssert(targetType.isAddress(), "Function type can only be converted to address.");
+ FunctionType const& typeOnStack = dynamic_cast<FunctionType const&>(_typeOnStack);
+ solAssert(typeOnStack.location() == FunctionType::Location::External, "Only external function type can be converted.");
+
+ // stack: <address> <function_id>
+ m_context << Instruction::POP;
+ break;
+ }
default:
// All other types should not be convertible to non-equal types.
solAssert(_typeOnStack == _targetType, "Invalid type conversion requested.");