Merge pull request #7807 from ethereum/no-private-override

Disallow use of virtual and private together
This commit is contained in:
chriseth 2019-11-27 19:02:52 +01:00 committed by GitHub
commit a57b12d17d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 24 additions and 5 deletions

View File

@ -21,6 +21,7 @@ Breaking changes:
* Natspec JSON Interface: Properly support multiple ``@return`` statements in ``@dev`` documentation and enforce named return parameters to be mentioned documentation. * Natspec JSON Interface: Properly support multiple ``@return`` statements in ``@dev`` documentation and enforce named return parameters to be mentioned documentation.
* Source mappings: Add "modifier depth" as a fifth field in the source mappings. * Source mappings: Add "modifier depth" as a fifth field in the source mappings.
* AST: Inline assembly is exported as structured JSON instead of plain string. * AST: Inline assembly is exported as structured JSON instead of plain string.
* General: ``private`` cannot be used together with ``virtual``.
Language Features: Language Features:
* Allow global enums and structs. * Allow global enums and structs.
@ -28,7 +29,7 @@ Language Features:
* Allow explicit conversions from ``address`` to ``address payable`` via ``payable(...)``. * Allow explicit conversions from ``address`` to ``address payable`` via ``payable(...)``.
* Introduce syntax for array slices and implement them for dynamic calldata arrays. * Introduce syntax for array slices and implement them for dynamic calldata arrays.
* Introduce ``push()`` for dynamic storage arrays. It returns a reference to the newly allocated element, if applicable. * Introduce ``push()`` for dynamic storage arrays. It returns a reference to the newly allocated element, if applicable.
* Introduce ``virtual`` and ``override`` keywords * Introduce ``virtual`` and ``override`` keywords.
* Modify ``push(element)`` for dynamic storage arrays such that it does not return the new length anymore. * Modify ``push(element)`` for dynamic storage arrays such that it does not return the new length anymore.
* Yul: Introduce ``leave`` statement that exits the current function. * Yul: Introduce ``leave`` statement that exits the current function.

View File

@ -181,8 +181,8 @@ Function Overriding
=================== ===================
Base functions can be overridden by inheriting contracts to change their Base functions can be overridden by inheriting contracts to change their
behavior. The overriding function must then use the ``override`` keyword in the behavior if they are marked as ``virtual``. The overriding function must then
function header as shown in this example: use the ``override`` keyword in the function header as shown in this example:
:: ::
@ -240,6 +240,11 @@ overridden when used with multiple inheritance:
// No explicit override required // No explicit override required
contract D is B, C {} contract D is B, C {}
.. note::
Functions with the ``private`` visibility cannot be ``virtual``.
.. _modifier-overriding: .. _modifier-overriding:
.. index:: ! overriding;modifier .. index:: ! overriding;modifier

View File

@ -327,8 +327,13 @@ bool TypeChecker::visit(FunctionDefinition const& _function)
{ {
bool isLibraryFunction = _function.inContractKind() == ContractDefinition::ContractKind::Library; bool isLibraryFunction = _function.inContractKind() == ContractDefinition::ContractKind::Library;
if (_function.markedVirtual() && _function.annotation().contract->isInterface()) if (_function.markedVirtual())
{
if (_function.annotation().contract->isInterface())
m_errorReporter.warning(_function.location(), "Interface functions are implicitly \"virtual\""); m_errorReporter.warning(_function.location(), "Interface functions are implicitly \"virtual\"");
if (_function.visibility() == Declaration::Visibility::Private)
m_errorReporter.typeError(_function.location(), "\"virtual\" and \"private\" cannot be used together.");
}
if (_function.isPayable()) if (_function.isPayable())
{ {

View File

@ -0,0 +1,8 @@
abstract contract A {
function test() private virtual returns (uint256);
}
abstract contract X is A {
function test() private override returns (uint256);
}
// ----
// TypeError: (23-73): "virtual" and "private" cannot be used together.