Type Checker: Disallow `virtual` for modifiers in libraries.

This commit is contained in:
Harikrishnan Mulackal 2020-09-07 10:45:04 +02:00
parent f964966090
commit acec8f271d
3 changed files with 17 additions and 0 deletions

View File

@ -8,6 +8,7 @@ Compiler Features:
* Yul Optimizer: Prune unused parameters in functions.
Bugfixes:
* Type Checker: Disallow ``virtual`` for modifiers in libraries.
### 0.7.1 (2020-09-02)

View File

@ -320,6 +320,15 @@ void TypeChecker::endVisit(InheritanceSpecifier const& _inheritance)
void TypeChecker::endVisit(ModifierDefinition const& _modifier)
{
if (_modifier.virtualSemantics())
if (auto const* contractDef = dynamic_cast<ContractDefinition const*>(_modifier.scope()))
if (contractDef->isLibrary())
m_errorReporter.typeError(
3275_error,
_modifier.location(),
"Modifiers in a library cannot be virtual."
);
if (!_modifier.isImplemented() && !_modifier.virtualSemantics())
m_errorReporter.typeError(8063_error, _modifier.location(), "Modifiers without implementation must be marked virtual.");
}

View File

@ -0,0 +1,7 @@
library test {
modifier m virtual;
function f() m public {
}
}
// ----
// TypeError 3275: (19-38): Modifiers in a library cannot be virtual.