mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Fix internal error in assignment chains that also assign to fully qualified state variables (, for example), where the contract expression is a tuble.
This commit is contained in:
parent
764569be16
commit
07870d0318
@ -25,6 +25,7 @@ Bugfixes:
|
|||||||
* SMTChecker: Improved readability for large integers that are powers of two or almost powers of two in error messages.
|
* SMTChecker: Improved readability for large integers that are powers of two or almost powers of two in error messages.
|
||||||
* SMTChecker: Fix internal error when a public library function is called internally.
|
* SMTChecker: Fix internal error when a public library function is called internally.
|
||||||
* SMTChecker: Fix internal error on multiple wrong SMTChecker natspec entries.
|
* SMTChecker: Fix internal error on multiple wrong SMTChecker natspec entries.
|
||||||
|
* SMTChecker: Fix internal error on chain assignments using static fully specified state variables.
|
||||||
|
|
||||||
|
|
||||||
### 0.8.17 (2022-09-08)
|
### 0.8.17 (2022-09-08)
|
||||||
|
@ -2757,7 +2757,9 @@ VariableDeclaration const* SMTEncoder::identifierToVariable(Expression const& _e
|
|||||||
}
|
}
|
||||||
// But we are interested in "contract.var", because that is the same as just "var".
|
// But we are interested in "contract.var", because that is the same as just "var".
|
||||||
if (auto const* memberAccess = dynamic_cast<MemberAccess const*>(&_expr))
|
if (auto const* memberAccess = dynamic_cast<MemberAccess const*>(&_expr))
|
||||||
if (dynamic_cast<ContractDefinition const*>(expressionToDeclaration(memberAccess->expression())))
|
if (dynamic_cast<ContractDefinition const*>(expressionToDeclaration(
|
||||||
|
*cleanExpression(memberAccess->expression())
|
||||||
|
)))
|
||||||
if (auto const* varDecl = dynamic_cast<VariableDeclaration const*>(memberAccess->annotation().referencedDeclaration))
|
if (auto const* varDecl = dynamic_cast<VariableDeclaration const*>(memberAccess->annotation().referencedDeclaration))
|
||||||
{
|
{
|
||||||
solAssert(m_context.knownVariable(*varDecl), "");
|
solAssert(m_context.knownVariable(*varDecl), "");
|
||||||
|
@ -0,0 +1,10 @@
|
|||||||
|
contract C {
|
||||||
|
string public name = (C).name = type(C).name;
|
||||||
|
|
||||||
|
function f() external view {
|
||||||
|
assert(keccak256(bytes(name)) == keccak256(bytes("C"))); // should fail because SMTChecker doesn't support type(C).name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// Warning 7507: (49-61): Assertion checker does not yet support this expression.
|
||||||
|
// Warning 6328: (105-160): CHC: Assertion violation happens here.\nCounterexample:\n\n\nTransaction trace:\nC.constructor()\nC.f()
|
@ -0,0 +1,13 @@
|
|||||||
|
contract C {
|
||||||
|
uint x = ((((C)))).x = ((C)).x = 2;
|
||||||
|
|
||||||
|
function f() external view {
|
||||||
|
assert(x == 2); // should hold
|
||||||
|
}
|
||||||
|
|
||||||
|
function g() external view {
|
||||||
|
assert(x != 2); // should fail
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// Warning 6328: (174-188): CHC: Assertion violation happens here.\nCounterexample:\nx = 2\n\nTransaction trace:\nC.constructor()\nState: x = 2\nC.g()
|
@ -0,0 +1,22 @@
|
|||||||
|
contract C {
|
||||||
|
uint x = ((((C)))).x = ((C)).x = 2;
|
||||||
|
|
||||||
|
function f() external view {
|
||||||
|
assert(x == 2); // should fail for D
|
||||||
|
}
|
||||||
|
|
||||||
|
function g() external view {
|
||||||
|
assert(x != 2); // should fail for C
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
contract D is C {
|
||||||
|
uint y = ((C)).x = 3;
|
||||||
|
|
||||||
|
function h() external view {
|
||||||
|
assert(y == 3); // should hold
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// Warning 6328: (95-109): CHC: Assertion violation happens here.\nCounterexample:\ny = 3, x = 3\n\nTransaction trace:\nD.constructor()\nState: y = 3, x = 3\nC.f()
|
||||||
|
// Warning 6328: (180-194): CHC: Assertion violation happens here.\nCounterexample:\nx = 2\n\nTransaction trace:\nC.constructor()\nState: x = 2\nC.g()
|
Loading…
Reference in New Issue
Block a user