mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Introduce inContractKind helper on FunctionDefinition
This commit is contained in:
parent
ef3595b000
commit
8bae2dba7c
@ -366,16 +366,6 @@ void TypeChecker::checkContractIllegalOverrides(ContractDefinition const& _contr
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
|
||||||
|
|
||||||
bool functionIsInInterface(FunctionDefinition const& _function)
|
|
||||||
{
|
|
||||||
return dynamic_cast<ContractDefinition const*>(_function.scope()) &&
|
|
||||||
dynamic_cast<ContractDefinition const*>(_function.scope())->contractKind() == ContractDefinition::ContractKind::Interface;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
void TypeChecker::checkFunctionOverride(FunctionDefinition const& function, FunctionDefinition const& super)
|
void TypeChecker::checkFunctionOverride(FunctionDefinition const& function, FunctionDefinition const& super)
|
||||||
{
|
{
|
||||||
FunctionType functionType(function);
|
FunctionType functionType(function);
|
||||||
@ -390,7 +380,11 @@ void TypeChecker::checkFunctionOverride(FunctionDefinition const& function, Func
|
|||||||
if (function.visibility() != super.visibility())
|
if (function.visibility() != super.visibility())
|
||||||
{
|
{
|
||||||
// visibility is enforced to be external in interfaces, but a contract can override that with public
|
// visibility is enforced to be external in interfaces, but a contract can override that with public
|
||||||
if (functionIsInInterface(super) && !functionIsInInterface(function) && function.visibility() == FunctionDefinition::Visibility::Public)
|
if (
|
||||||
|
super.inContractKind() == ContractDefinition::ContractKind::Interface &&
|
||||||
|
function.inContractKind() != ContractDefinition::ContractKind::Interface &&
|
||||||
|
function.visibility() == FunctionDefinition::Visibility::Public
|
||||||
|
)
|
||||||
return;
|
return;
|
||||||
overrideError(function, super, "Overriding function visibility differs.");
|
overrideError(function, super, "Overriding function visibility differs.");
|
||||||
}
|
}
|
||||||
|
@ -290,6 +290,13 @@ TypeDeclarationAnnotation& EnumDefinition::annotation() const
|
|||||||
return dynamic_cast<TypeDeclarationAnnotation&>(*m_annotation);
|
return dynamic_cast<TypeDeclarationAnnotation&>(*m_annotation);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ContractDefinition::ContractKind FunctionDefinition::inContractKind() const
|
||||||
|
{
|
||||||
|
auto contractDef = dynamic_cast<ContractDefinition const*>(scope());
|
||||||
|
solAssert(contractDef, "Enclosing Scope of FunctionDefinition was not set.");
|
||||||
|
return contractDef->contractKind();
|
||||||
|
}
|
||||||
|
|
||||||
shared_ptr<FunctionType> FunctionDefinition::functionType(bool _internal) const
|
shared_ptr<FunctionType> FunctionDefinition::functionType(bool _internal) const
|
||||||
{
|
{
|
||||||
if (_internal)
|
if (_internal)
|
||||||
|
@ -624,6 +624,8 @@ public:
|
|||||||
/// arguments separated by commas all enclosed in parentheses without any spaces.
|
/// arguments separated by commas all enclosed in parentheses without any spaces.
|
||||||
std::string externalSignature() const;
|
std::string externalSignature() const;
|
||||||
|
|
||||||
|
ContractDefinition::ContractKind inContractKind() const;
|
||||||
|
|
||||||
virtual TypePointer type() const override;
|
virtual TypePointer type() const override;
|
||||||
|
|
||||||
/// @param _internal false indicates external interface is concerned, true indicates internal interface is concerned.
|
/// @param _internal false indicates external interface is concerned, true indicates internal interface is concerned.
|
||||||
|
Loading…
Reference in New Issue
Block a user