Merge pull request #7019 from ethereum/smt_fix_require

[SMTChecker] Fix require with message
This commit is contained in:
chriseth 2019-07-02 13:13:50 +02:00 committed by GitHub
commit 06d01d1573
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 15 additions and 6 deletions

View File

@ -386,7 +386,7 @@ void BMC::visitAssert(FunctionCall const& _funCall)
void BMC::visitRequire(FunctionCall const& _funCall)
{
auto const& args = _funCall.arguments();
solAssert(args.size() == 1, "");
solAssert(args.size() >= 1, "");
solAssert(args.front()->annotation().type->category() == Type::Category::Bool, "");
if (isRootFunction())
addVerificationTarget(

View File

@ -501,16 +501,16 @@ void SMTEncoder::visitAssert(FunctionCall const& _funCall)
{
auto const& args = _funCall.arguments();
solAssert(args.size() == 1, "");
solAssert(args[0]->annotation().type->category() == Type::Category::Bool, "");
addPathImpliedExpression(expr(*args[0]));
solAssert(args.front()->annotation().type->category() == Type::Category::Bool, "");
addPathImpliedExpression(expr(*args.front()));
}
void SMTEncoder::visitRequire(FunctionCall const& _funCall)
{
auto const& args = _funCall.arguments();
solAssert(args.size() == 1, "");
solAssert(args[0]->annotation().type->category() == Type::Category::Bool, "");
addPathImpliedExpression(expr(*args[0]));
solAssert(args.size() >= 1, "");
solAssert(args.front()->annotation().type->category() == Type::Category::Bool, "");
addPathImpliedExpression(expr(*args.front()));
}
void SMTEncoder::visitGasLeft(FunctionCall const& _funCall)

View File

@ -0,0 +1,9 @@
pragma experimental SMTChecker;
contract C {
function f(uint a) public pure {
require(a < 10, "Input number is too large.");
assert(a < 20);
}
}
// ----
// Warning: (97-125): Assertion checker does not yet support the type of this literal (literal_string "Input number is too large.").