mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Support explicit conversion of external function type to address
This commit is contained in:
parent
c1a675da4f
commit
767ec1d670
@ -2158,6 +2158,17 @@ bool FunctionType::operator==(Type const& _other) const
|
||||
return true;
|
||||
}
|
||||
|
||||
bool FunctionType::isExplicitlyConvertibleTo(Type const& _convertTo) const
|
||||
{
|
||||
if (m_location == Location::External && _convertTo.category() == Category::Integer)
|
||||
{
|
||||
IntegerType const& convertTo = dynamic_cast<IntegerType const&>(_convertTo);
|
||||
if (convertTo.isAddress())
|
||||
return true;
|
||||
}
|
||||
return _convertTo.category() == category();
|
||||
}
|
||||
|
||||
TypePointer FunctionType::unaryOperatorResult(Token::Value _operator) const
|
||||
{
|
||||
if (_operator == Token::Value::Delete)
|
||||
|
@ -922,6 +922,7 @@ public:
|
||||
|
||||
virtual std::string identifier() const override;
|
||||
virtual bool operator==(Type const& _other) const override;
|
||||
virtual bool isExplicitlyConvertibleTo(Type const& _convertTo) const override;
|
||||
virtual TypePointer unaryOperatorResult(Token::Value _operator) const override;
|
||||
virtual std::string canonicalName(bool /*_addDataLocation*/) const override;
|
||||
virtual std::string toString(bool _short) const override;
|
||||
|
@ -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.");
|
||||
|
@ -42,7 +42,7 @@ class StackHeightChecker
|
||||
public:
|
||||
StackHeightChecker(CompilerContext const& _context):
|
||||
m_context(_context), stackHeight(m_context.stackHeight()) {}
|
||||
void check() { solAssert(m_context.stackHeight() == stackHeight, "I sense a disturbance in the stack."); }
|
||||
void check() { solAssert(m_context.stackHeight() == stackHeight, "I sense a disturbance in the stack. "); }
|
||||
private:
|
||||
CompilerContext const& m_context;
|
||||
unsigned stackHeight;
|
||||
|
Loading…
Reference in New Issue
Block a user