Properly handle invalid references used together with _slot and _offset.

This commit is contained in:
Alex Beregszaszi 2018-08-07 12:13:52 +01:00
parent 8b2d630275
commit eb7b3862ac
3 changed files with 12 additions and 0 deletions

View File

@ -83,6 +83,7 @@ Bugfixes:
* Fix NatSpec json output for `@notice` and `@dev` tags on contract definitions.
* References Resolver: Do not crash on using ``_slot`` and ``_offset`` suffixes on their own.
* References Resolver: Enforce ``storage`` as data location for mappings.
* References Resolver: Properly handle invalid references used together with ``_slot`` and ``_offset``.
* References Resolver: Report error instead of assertion fail when FunctionType has an undeclared type as parameter.
* Type Checker: Disallow assignments to mappings within tuple assignments as well.
* Type Checker: Allow assignments to local variables of mapping types.

View File

@ -262,6 +262,8 @@ bool ReferencesResolver::visit(InlineAssembly const& _inlineAssembly)
return size_t(-1);
}
declarations = m_resolver.nameFromCurrentScope(realName);
if (!dynamic_cast<VariableDeclaration const*>(declarations.front()))
return size_t(-1);
}
if (declarations.size() != 1)
return size_t(-1);

View File

@ -0,0 +1,9 @@
contract C {
function f() pure public {
assembly {
let x := f_slot
}
}
}
// ----
// DeclarationError: (84-90): Identifier not found.