diff options
author | Alex Beregszaszi <alex@rtfs.hu> | 2017-08-12 07:45:37 +0800 |
---|---|---|
committer | Alex Beregszaszi <alex@rtfs.hu> | 2017-08-22 06:02:18 +0800 |
commit | b25f0c52ac01857a82dda20ec2b646c7ae90cd7d (patch) | |
tree | 4148fa30c5386136ab7dc476ff61bba26a2bcc2c /libsolidity | |
parent | 2c2ae74217521aae93b9c7b058ce8687046c648c (diff) | |
download | dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.tar dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.tar.gz dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.tar.bz2 dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.tar.lz dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.tar.xz dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.tar.zst dexon-solidity-b25f0c52ac01857a82dda20ec2b646c7ae90cd7d.zip |
Reject the creation of interface with the new statement
Diffstat (limited to 'libsolidity')
-rw-r--r-- | libsolidity/analysis/TypeChecker.cpp | 6 | ||||
-rw-r--r-- | libsolidity/ast/Types.cpp | 3 |
2 files changed, 9 insertions, 0 deletions
diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp index 32d078fd..f70b75d3 100644 --- a/libsolidity/analysis/TypeChecker.cpp +++ b/libsolidity/analysis/TypeChecker.cpp @@ -429,6 +429,10 @@ void TypeChecker::endVisit(InheritanceSpecifier const& _inheritance) if (base->isLibrary()) m_errorReporter.typeError(_inheritance.location(), "Libraries cannot be inherited from."); + // Interface can have no constructors - no need to validate + if (base->contractKind() == ContractDefinition::ContractKind::Interface) + return; + auto const& arguments = _inheritance.arguments(); TypePointers parameterTypes = ContractType(*base).newExpressionType()->parameterTypes(); if (!arguments.empty() && parameterTypes.size() != arguments.size()) @@ -1554,6 +1558,8 @@ void TypeChecker::endVisit(NewExpression const& _newExpression) if (!contract) m_errorReporter.fatalTypeError(_newExpression.location(), "Identifier is not a contract."); + if (contract->contractKind() == ContractDefinition::ContractKind::Interface) + m_errorReporter.fatalTypeError(_newExpression.location(), "Cannot instantiate an interface."); if (!contract->annotation().unimplementedFunctions.empty()) m_errorReporter.typeError( _newExpression.location(), diff --git a/libsolidity/ast/Types.cpp b/libsolidity/ast/Types.cpp index e6664895..adf41229 100644 --- a/libsolidity/ast/Types.cpp +++ b/libsolidity/ast/Types.cpp @@ -2140,6 +2140,8 @@ FunctionTypePointer FunctionType::newExpressionType(ContractDefinition const& _c strings parameterNames; StateMutability stateMutability = StateMutability::NonPayable; + solAssert(_contract.contractKind() != ContractDefinition::ContractKind::Interface, ""); + if (constructor) { for (ASTPointer<VariableDeclaration> const& var: constructor->parameters()) @@ -2150,6 +2152,7 @@ FunctionTypePointer FunctionType::newExpressionType(ContractDefinition const& _c if (constructor->isPayable()) stateMutability = StateMutability::Payable; } + return make_shared<FunctionType>( parameters, TypePointers{make_shared<ContractType>(_contract)}, |