From 7e5406dd8953cb819c397221fa55e6fa390108ee Mon Sep 17 00:00:00 2001 From: chriseth Date: Fri, 29 Jun 2018 00:06:51 +0200 Subject: [PATCH] Disallow calling base constructors without arguments. --- Changelog.md | 1 + libsolidity/analysis/TypeChecker.cpp | 18 ++++-------------- ...llow_modifier_style_without_parentheses.sol | 2 +- 3 files changed, 6 insertions(+), 15 deletions(-) diff --git a/Changelog.md b/Changelog.md index bcd559554..7f92a3def 100644 --- a/Changelog.md +++ b/Changelog.md @@ -39,6 +39,7 @@ Breaking Changes: * Type Checker: Disallow values for constants that are not compile-time constants. This was already the case in the experimental 0.5.0 mode. * Type Checker: Disallow arithmetic operations for boolean variables. * Type Checker: Disallow tight packing of literals. This was already the case in the experimental 0.5.0 mode. + * Type Checker: Disallow calling base constructors without parentheses. This was already the case in the experimental 0.5.0 mode. * Type Checker: Disallow conversions between ``bytesX`` and ``uintY`` of different size. * Type Checker: Disallow conversions between unrelated contract types. Explicit conversion via ``address`` can still achieve it. * Type Checker: Disallow empty tuple components. This was partly already the case in the experimental 0.5.0 mode. diff --git a/libsolidity/analysis/TypeChecker.cpp b/libsolidity/analysis/TypeChecker.cpp index d2fb92817..9e10b9b20 100644 --- a/libsolidity/analysis/TypeChecker.cpp +++ b/libsolidity/analysis/TypeChecker.cpp @@ -279,8 +279,6 @@ void TypeChecker::checkContractAbstractFunctions(ContractDefinition const& _cont void TypeChecker::checkContractBaseConstructorArguments(ContractDefinition const& _contract) { - bool const v050 = _contract.sourceUnit().annotation().experimentalFeatures.count(ExperimentalFeature::V050); - vector const& bases = _contract.annotation().linearizedBaseContracts; // Determine the arguments that are used for the base constructors. @@ -296,18 +294,10 @@ void TypeChecker::checkContractBaseConstructorArguments(ContractDefinition const annotateBaseConstructorArguments(_contract, baseContract->constructor(), modifier.get()); } else - { - if (v050) - m_errorReporter.declarationError( - modifier->location(), - "Modifier-style base constructor call without arguments." - ); - else - m_errorReporter.warning( - modifier->location(), - "Modifier-style base constructor call without arguments." - ); - } + m_errorReporter.declarationError( + modifier->location(), + "Modifier-style base constructor call without arguments." + ); } for (ASTPointer const& base: contract->baseContracts()) diff --git a/test/libsolidity/syntaxTests/inheritance/disallow_modifier_style_without_parentheses.sol b/test/libsolidity/syntaxTests/inheritance/disallow_modifier_style_without_parentheses.sol index 6cf68d2aa..8f5ceef89 100644 --- a/test/libsolidity/syntaxTests/inheritance/disallow_modifier_style_without_parentheses.sol +++ b/test/libsolidity/syntaxTests/inheritance/disallow_modifier_style_without_parentheses.sol @@ -1,4 +1,4 @@ contract A { constructor() public { } } contract B is A { constructor() A public { } } // ---- -// Warning: (72-73): Modifier-style base constructor call without arguments. +// DeclarationError: (72-73): Modifier-style base constructor call without arguments.