mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
SMTChecker: fixed struct constructor where FixedBytes member is initialized with a string literal
This commit is contained in:
parent
1d41ceaed4
commit
9c98ab59f0
@ -13,6 +13,7 @@ Compiler Features:
|
|||||||
|
|
||||||
Bugfixes:
|
Bugfixes:
|
||||||
* AST: Do not output value of Yul literal if it is not a valid UTF-8 string.
|
* AST: Do not output value of Yul literal if it is not a valid UTF-8 string.
|
||||||
|
* SMTChecker: Fix internal error on struct constructor with fixed bytes member initialized with string literal.
|
||||||
|
|
||||||
|
|
||||||
AST Changes:
|
AST Changes:
|
||||||
|
@ -1158,7 +1158,15 @@ void SMTEncoder::visitStructConstructorCall(FunctionCall const& _funCall)
|
|||||||
if (smt::isNonRecursiveStruct(*_funCall.annotation().type))
|
if (smt::isNonRecursiveStruct(*_funCall.annotation().type))
|
||||||
{
|
{
|
||||||
auto& structSymbolicVar = dynamic_cast<smt::SymbolicStructVariable&>(*m_context.expression(_funCall));
|
auto& structSymbolicVar = dynamic_cast<smt::SymbolicStructVariable&>(*m_context.expression(_funCall));
|
||||||
structSymbolicVar.assignAllMembers(applyMap(_funCall.sortedArguments(), [this](auto const& arg) { return expr(*arg); }));
|
auto structType = dynamic_cast<StructType const*>(structSymbolicVar.type());
|
||||||
|
solAssert(structType, "");
|
||||||
|
auto const& structMembers = structType->structDefinition().members();
|
||||||
|
solAssert(structMembers.size() == _funCall.sortedArguments().size(), "");
|
||||||
|
auto args = _funCall.sortedArguments();
|
||||||
|
structSymbolicVar.assignAllMembers(applyMap(
|
||||||
|
ranges::views::zip(args, structMembers),
|
||||||
|
[this] (auto const& argMemberPair) { return expr(*argMemberPair.first, argMemberPair.second->type()); }
|
||||||
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,14 @@
|
|||||||
|
pragma experimental SMTChecker;
|
||||||
|
contract C {
|
||||||
|
struct S {
|
||||||
|
int a;
|
||||||
|
bytes5 b;
|
||||||
|
}
|
||||||
|
function f() public pure {
|
||||||
|
assert(S({a:2, b:""}).b == bytes5(0)); // should hold
|
||||||
|
assert(S({a:2, b:""}).a == 0); // should fail
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// ----
|
||||||
|
// Warning 5523: (0-31): The SMTChecker pragma has been deprecated and will be removed in the future. Please use the "model checker engine" compiler setting to activate the SMTChecker instead. If the pragma is enabled, all engines will be used.
|
||||||
|
// Warning 6328: (178-207): CHC: Assertion violation happens here.\nCounterexample:\n\n\nTransaction trace:\nC.constructor()\nC.f()
|
Loading…
Reference in New Issue
Block a user