mirror of
https://github.com/ethereum/solidity
synced 2023-10-03 13:03:40 +00:00
Merge pull request #7040 from ethereum/smt_context_vars
[SMTChecker] SymbolicVariables use EncodingContext to declare SMT vars
This commit is contained in:
commit
3b2ebba472
@ -459,7 +459,7 @@ void BMC::abstractFunctionCall(FunctionCall const& _funCall)
|
|||||||
smtArguments.push_back(expr(*arg));
|
smtArguments.push_back(expr(*arg));
|
||||||
defineExpr(_funCall, (*m_context.expression(_funCall.expression()))(smtArguments));
|
defineExpr(_funCall, (*m_context.expression(_funCall.expression()))(smtArguments));
|
||||||
m_uninterpretedTerms.insert(&_funCall);
|
m_uninterpretedTerms.insert(&_funCall);
|
||||||
setSymbolicUnknownValue(expr(_funCall), _funCall.annotation().type, *m_context.solver());
|
setSymbolicUnknownValue(expr(_funCall), _funCall.annotation().type, m_context);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BMC::internalOrExternalFunctionCall(FunctionCall const& _funCall)
|
void BMC::internalOrExternalFunctionCall(FunctionCall const& _funCall)
|
||||||
|
@ -24,14 +24,14 @@ using namespace dev;
|
|||||||
using namespace dev::solidity::smt;
|
using namespace dev::solidity::smt;
|
||||||
|
|
||||||
EncodingContext::EncodingContext(std::shared_ptr<SolverInterface> _solver):
|
EncodingContext::EncodingContext(std::shared_ptr<SolverInterface> _solver):
|
||||||
m_thisAddress(make_unique<SymbolicAddressVariable>("this", *_solver)),
|
m_thisAddress(make_unique<SymbolicAddressVariable>("this", *this)),
|
||||||
m_solver(_solver)
|
m_solver(_solver)
|
||||||
{
|
{
|
||||||
auto sort = make_shared<ArraySort>(
|
auto sort = make_shared<ArraySort>(
|
||||||
make_shared<Sort>(Kind::Int),
|
make_shared<Sort>(Kind::Int),
|
||||||
make_shared<Sort>(Kind::Int)
|
make_shared<Sort>(Kind::Int)
|
||||||
);
|
);
|
||||||
m_balances = make_unique<SymbolicVariable>(sort, "balances", *m_solver);
|
m_balances = make_unique<SymbolicVariable>(sort, "balances", *this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EncodingContext::reset()
|
void EncodingContext::reset()
|
||||||
@ -56,7 +56,7 @@ bool EncodingContext::createVariable(solidity::VariableDeclaration const& _varDe
|
|||||||
{
|
{
|
||||||
solAssert(!knownVariable(_varDecl), "");
|
solAssert(!knownVariable(_varDecl), "");
|
||||||
auto const& type = _varDecl.type();
|
auto const& type = _varDecl.type();
|
||||||
auto result = newSymbolicVariable(*type, _varDecl.name() + "_" + to_string(_varDecl.id()), *m_solver);
|
auto result = newSymbolicVariable(*type, _varDecl.name() + "_" + to_string(_varDecl.id()), *this);
|
||||||
m_variables.emplace(&_varDecl, result.second);
|
m_variables.emplace(&_varDecl, result.second);
|
||||||
return result.first;
|
return result.first;
|
||||||
}
|
}
|
||||||
@ -106,7 +106,7 @@ void EncodingContext::setZeroValue(solidity::VariableDeclaration const& _decl)
|
|||||||
|
|
||||||
void EncodingContext::setZeroValue(SymbolicVariable& _variable)
|
void EncodingContext::setZeroValue(SymbolicVariable& _variable)
|
||||||
{
|
{
|
||||||
setSymbolicZeroValue(_variable, *m_solver);
|
setSymbolicZeroValue(_variable, *this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void EncodingContext::setUnknownValue(solidity::VariableDeclaration const& _decl)
|
void EncodingContext::setUnknownValue(solidity::VariableDeclaration const& _decl)
|
||||||
@ -117,7 +117,7 @@ void EncodingContext::setUnknownValue(solidity::VariableDeclaration const& _decl
|
|||||||
|
|
||||||
void EncodingContext::setUnknownValue(SymbolicVariable& _variable)
|
void EncodingContext::setUnknownValue(SymbolicVariable& _variable)
|
||||||
{
|
{
|
||||||
setSymbolicUnknownValue(_variable, *m_solver);
|
setSymbolicUnknownValue(_variable, *this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Expressions
|
/// Expressions
|
||||||
@ -144,7 +144,7 @@ bool EncodingContext::createExpression(solidity::Expression const& _e, shared_pt
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
auto result = newSymbolicVariable(*_e.annotation().type, "expr_" + to_string(_e.id()), *m_solver);
|
auto result = newSymbolicVariable(*_e.annotation().type, "expr_" + to_string(_e.id()), *this);
|
||||||
m_expressions.emplace(&_e, result.second);
|
m_expressions.emplace(&_e, result.second);
|
||||||
return result.first;
|
return result.first;
|
||||||
}
|
}
|
||||||
@ -166,7 +166,7 @@ shared_ptr<SymbolicVariable> EncodingContext::globalSymbol(string const& _name)
|
|||||||
bool EncodingContext::createGlobalSymbol(string const& _name, solidity::Expression const& _expr)
|
bool EncodingContext::createGlobalSymbol(string const& _name, solidity::Expression const& _expr)
|
||||||
{
|
{
|
||||||
solAssert(!knownGlobalSymbol(_name), "");
|
solAssert(!knownGlobalSymbol(_name), "");
|
||||||
auto result = newSymbolicVariable(*_expr.annotation().type, _name, *m_solver);
|
auto result = newSymbolicVariable(*_expr.annotation().type, _name, *this);
|
||||||
m_globalContext.emplace(_name, result.second);
|
m_globalContext.emplace(_name, result.second);
|
||||||
setUnknownValue(*result.second);
|
setUnknownValue(*result.second);
|
||||||
return result.first;
|
return result.first;
|
||||||
|
@ -41,6 +41,13 @@ public:
|
|||||||
/// Resets the entire context.
|
/// Resets the entire context.
|
||||||
void reset();
|
void reset();
|
||||||
|
|
||||||
|
/// Forwards variable creation to the solver.
|
||||||
|
Expression newVariable(std::string _name, SortPointer _sort)
|
||||||
|
{
|
||||||
|
solAssert(m_solver, "");
|
||||||
|
return m_solver->newVariable(move(_name), move(_sort));
|
||||||
|
}
|
||||||
|
|
||||||
/// Variables.
|
/// Variables.
|
||||||
//@{
|
//@{
|
||||||
/// @returns the symbolic representation of a program variable.
|
/// @returns the symbolic representation of a program variable.
|
||||||
|
@ -473,7 +473,7 @@ void SMTEncoder::endVisit(FunctionCall const& _funCall)
|
|||||||
solAssert(value, "");
|
solAssert(value, "");
|
||||||
|
|
||||||
smt::Expression thisBalance = m_context.balance();
|
smt::Expression thisBalance = m_context.balance();
|
||||||
setSymbolicUnknownValue(thisBalance, TypeProvider::uint256(), *m_context.solver());
|
setSymbolicUnknownValue(thisBalance, TypeProvider::uint256(), m_context);
|
||||||
|
|
||||||
m_context.transfer(m_context.thisAddress(), expr(address), expr(*value));
|
m_context.transfer(m_context.thisAddress(), expr(address), expr(*value));
|
||||||
break;
|
break;
|
||||||
@ -615,7 +615,7 @@ void SMTEncoder::endVisit(Literal const& _literal)
|
|||||||
auto stringType = TypeProvider::stringMemory();
|
auto stringType = TypeProvider::stringMemory();
|
||||||
auto stringLit = dynamic_cast<StringLiteralType const*>(_literal.annotation().type);
|
auto stringLit = dynamic_cast<StringLiteralType const*>(_literal.annotation().type);
|
||||||
solAssert(stringLit, "");
|
solAssert(stringLit, "");
|
||||||
auto result = smt::newSymbolicVariable(*stringType, stringLit->richIdentifier(), *m_context.solver());
|
auto result = smt::newSymbolicVariable(*stringType, stringLit->richIdentifier(), m_context);
|
||||||
m_context.createExpression(_literal, result.second);
|
m_context.createExpression(_literal, result.second);
|
||||||
}
|
}
|
||||||
m_errorReporter.warning(
|
m_errorReporter.warning(
|
||||||
@ -687,7 +687,7 @@ bool SMTEncoder::visit(MemberAccess const& _memberAccess)
|
|||||||
if (_memberAccess.memberName() == "balance")
|
if (_memberAccess.memberName() == "balance")
|
||||||
{
|
{
|
||||||
defineExpr(_memberAccess, m_context.balance(expr(_memberAccess.expression())));
|
defineExpr(_memberAccess, m_context.balance(expr(_memberAccess.expression())));
|
||||||
setSymbolicUnknownValue(*m_context.expression(_memberAccess), *m_context.solver());
|
setSymbolicUnknownValue(*m_context.expression(_memberAccess), m_context);
|
||||||
m_uninterpretedTerms.insert(&_memberAccess);
|
m_uninterpretedTerms.insert(&_memberAccess);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -734,7 +734,7 @@ void SMTEncoder::endVisit(IndexAccess const& _indexAccess)
|
|||||||
setSymbolicUnknownValue(
|
setSymbolicUnknownValue(
|
||||||
expr(_indexAccess),
|
expr(_indexAccess),
|
||||||
_indexAccess.annotation().type,
|
_indexAccess.annotation().type,
|
||||||
*m_context.solver()
|
m_context
|
||||||
);
|
);
|
||||||
m_uninterpretedTerms.insert(&_indexAccess);
|
m_uninterpretedTerms.insert(&_indexAccess);
|
||||||
}
|
}
|
||||||
|
@ -118,7 +118,7 @@ bool isSupportedTypeDeclaration(solidity::Type::Category _category)
|
|||||||
pair<bool, shared_ptr<SymbolicVariable>> newSymbolicVariable(
|
pair<bool, shared_ptr<SymbolicVariable>> newSymbolicVariable(
|
||||||
solidity::Type const& _type,
|
solidity::Type const& _type,
|
||||||
std::string const& _uniqueName,
|
std::string const& _uniqueName,
|
||||||
SolverInterface& _solver
|
EncodingContext& _context
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
bool abstract = false;
|
bool abstract = false;
|
||||||
@ -127,39 +127,39 @@ pair<bool, shared_ptr<SymbolicVariable>> newSymbolicVariable(
|
|||||||
if (!isSupportedTypeDeclaration(_type))
|
if (!isSupportedTypeDeclaration(_type))
|
||||||
{
|
{
|
||||||
abstract = true;
|
abstract = true;
|
||||||
var = make_shared<SymbolicIntVariable>(solidity::TypeProvider::uint256(), _uniqueName, _solver);
|
var = make_shared<SymbolicIntVariable>(solidity::TypeProvider::uint256(), _uniqueName, _context);
|
||||||
}
|
}
|
||||||
else if (isBool(_type.category()))
|
else if (isBool(_type.category()))
|
||||||
var = make_shared<SymbolicBoolVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicBoolVariable>(type, _uniqueName, _context);
|
||||||
else if (isFunction(_type.category()))
|
else if (isFunction(_type.category()))
|
||||||
var = make_shared<SymbolicFunctionVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicFunctionVariable>(type, _uniqueName, _context);
|
||||||
else if (isInteger(_type.category()))
|
else if (isInteger(_type.category()))
|
||||||
var = make_shared<SymbolicIntVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicIntVariable>(type, _uniqueName, _context);
|
||||||
else if (isFixedBytes(_type.category()))
|
else if (isFixedBytes(_type.category()))
|
||||||
{
|
{
|
||||||
auto fixedBytesType = dynamic_cast<solidity::FixedBytesType const*>(type);
|
auto fixedBytesType = dynamic_cast<solidity::FixedBytesType const*>(type);
|
||||||
solAssert(fixedBytesType, "");
|
solAssert(fixedBytesType, "");
|
||||||
var = make_shared<SymbolicFixedBytesVariable>(fixedBytesType->numBytes(), _uniqueName, _solver);
|
var = make_shared<SymbolicFixedBytesVariable>(fixedBytesType->numBytes(), _uniqueName, _context);
|
||||||
}
|
}
|
||||||
else if (isAddress(_type.category()) || isContract(_type.category()))
|
else if (isAddress(_type.category()) || isContract(_type.category()))
|
||||||
var = make_shared<SymbolicAddressVariable>(_uniqueName, _solver);
|
var = make_shared<SymbolicAddressVariable>(_uniqueName, _context);
|
||||||
else if (isEnum(_type.category()))
|
else if (isEnum(_type.category()))
|
||||||
var = make_shared<SymbolicEnumVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicEnumVariable>(type, _uniqueName, _context);
|
||||||
else if (isRational(_type.category()))
|
else if (isRational(_type.category()))
|
||||||
{
|
{
|
||||||
auto rational = dynamic_cast<solidity::RationalNumberType const*>(&_type);
|
auto rational = dynamic_cast<solidity::RationalNumberType const*>(&_type);
|
||||||
solAssert(rational, "");
|
solAssert(rational, "");
|
||||||
if (rational->isFractional())
|
if (rational->isFractional())
|
||||||
var = make_shared<SymbolicIntVariable>(solidity::TypeProvider::uint256(), _uniqueName, _solver);
|
var = make_shared<SymbolicIntVariable>(solidity::TypeProvider::uint256(), _uniqueName, _context);
|
||||||
else
|
else
|
||||||
var = make_shared<SymbolicIntVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicIntVariable>(type, _uniqueName, _context);
|
||||||
}
|
}
|
||||||
else if (isMapping(_type.category()))
|
else if (isMapping(_type.category()))
|
||||||
var = make_shared<SymbolicMappingVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicMappingVariable>(type, _uniqueName, _context);
|
||||||
else if (isArray(_type.category()))
|
else if (isArray(_type.category()))
|
||||||
var = make_shared<SymbolicArrayVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicArrayVariable>(type, _uniqueName, _context);
|
||||||
else if (isTuple(_type.category()))
|
else if (isTuple(_type.category()))
|
||||||
var = make_shared<SymbolicTupleVariable>(type, _uniqueName, _solver);
|
var = make_shared<SymbolicTupleVariable>(type, _uniqueName, _context);
|
||||||
else
|
else
|
||||||
solAssert(false, "");
|
solAssert(false, "");
|
||||||
return make_pair(abstract, var);
|
return make_pair(abstract, var);
|
||||||
@ -250,41 +250,41 @@ Expression maxValue(solidity::IntegerType const& _type)
|
|||||||
return Expression(_type.maxValue());
|
return Expression(_type.maxValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
void setSymbolicZeroValue(SymbolicVariable const& _variable, SolverInterface& _interface)
|
void setSymbolicZeroValue(SymbolicVariable const& _variable, EncodingContext& _context)
|
||||||
{
|
{
|
||||||
setSymbolicZeroValue(_variable.currentValue(), _variable.type(), _interface);
|
setSymbolicZeroValue(_variable.currentValue(), _variable.type(), _context);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setSymbolicZeroValue(Expression _expr, solidity::TypePointer const& _type, SolverInterface& _interface)
|
void setSymbolicZeroValue(Expression _expr, solidity::TypePointer const& _type, EncodingContext& _context)
|
||||||
{
|
{
|
||||||
solAssert(_type, "");
|
solAssert(_type, "");
|
||||||
if (isInteger(_type->category()))
|
if (isInteger(_type->category()))
|
||||||
_interface.addAssertion(_expr == 0);
|
_context.addAssertion(_expr == 0);
|
||||||
else if (isBool(_type->category()))
|
else if (isBool(_type->category()))
|
||||||
_interface.addAssertion(_expr == Expression(false));
|
_context.addAssertion(_expr == Expression(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
void setSymbolicUnknownValue(SymbolicVariable const& _variable, SolverInterface& _interface)
|
void setSymbolicUnknownValue(SymbolicVariable const& _variable, EncodingContext& _context)
|
||||||
{
|
{
|
||||||
setSymbolicUnknownValue(_variable.currentValue(), _variable.type(), _interface);
|
setSymbolicUnknownValue(_variable.currentValue(), _variable.type(), _context);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setSymbolicUnknownValue(Expression _expr, solidity::TypePointer const& _type, SolverInterface& _interface)
|
void setSymbolicUnknownValue(Expression _expr, solidity::TypePointer const& _type, EncodingContext& _context)
|
||||||
{
|
{
|
||||||
solAssert(_type, "");
|
solAssert(_type, "");
|
||||||
if (isEnum(_type->category()))
|
if (isEnum(_type->category()))
|
||||||
{
|
{
|
||||||
auto enumType = dynamic_cast<solidity::EnumType const*>(_type);
|
auto enumType = dynamic_cast<solidity::EnumType const*>(_type);
|
||||||
solAssert(enumType, "");
|
solAssert(enumType, "");
|
||||||
_interface.addAssertion(_expr >= 0);
|
_context.addAssertion(_expr >= 0);
|
||||||
_interface.addAssertion(_expr < enumType->numberOfMembers());
|
_context.addAssertion(_expr < enumType->numberOfMembers());
|
||||||
}
|
}
|
||||||
else if (isInteger(_type->category()))
|
else if (isInteger(_type->category()))
|
||||||
{
|
{
|
||||||
auto intType = dynamic_cast<solidity::IntegerType const*>(_type);
|
auto intType = dynamic_cast<solidity::IntegerType const*>(_type);
|
||||||
solAssert(intType, "");
|
solAssert(intType, "");
|
||||||
_interface.addAssertion(_expr >= minValue(*intType));
|
_context.addAssertion(_expr >= minValue(*intType));
|
||||||
_interface.addAssertion(_expr <= maxValue(*intType));
|
_context.addAssertion(_expr <= maxValue(*intType));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <libsolidity/formal/SolverInterface.h>
|
#include <libsolidity/formal/EncodingContext.h>
|
||||||
#include <libsolidity/formal/SymbolicVariables.h>
|
#include <libsolidity/formal/SymbolicVariables.h>
|
||||||
#include <libsolidity/ast/AST.h>
|
#include <libsolidity/ast/AST.h>
|
||||||
#include <libsolidity/ast/Types.h>
|
#include <libsolidity/ast/Types.h>
|
||||||
@ -58,15 +58,15 @@ bool isTuple(solidity::Type::Category _category);
|
|||||||
/// Returns a new symbolic variable, according to _type.
|
/// Returns a new symbolic variable, according to _type.
|
||||||
/// Also returns whether the type is abstract or not,
|
/// Also returns whether the type is abstract or not,
|
||||||
/// which is true for unsupported types.
|
/// which is true for unsupported types.
|
||||||
std::pair<bool, std::shared_ptr<SymbolicVariable>> newSymbolicVariable(solidity::Type const& _type, std::string const& _uniqueName, SolverInterface& _solver);
|
std::pair<bool, std::shared_ptr<SymbolicVariable>> newSymbolicVariable(solidity::Type const& _type, std::string const& _uniqueName, EncodingContext& _context);
|
||||||
|
|
||||||
Expression minValue(solidity::IntegerType const& _type);
|
Expression minValue(solidity::IntegerType const& _type);
|
||||||
Expression maxValue(solidity::IntegerType const& _type);
|
Expression maxValue(solidity::IntegerType const& _type);
|
||||||
|
|
||||||
void setSymbolicZeroValue(SymbolicVariable const& _variable, SolverInterface& _interface);
|
void setSymbolicZeroValue(SymbolicVariable const& _variable, EncodingContext& _context);
|
||||||
void setSymbolicZeroValue(Expression _expr, solidity::TypePointer const& _type, SolverInterface& _interface);
|
void setSymbolicZeroValue(Expression _expr, solidity::TypePointer const& _type, EncodingContext& _context);
|
||||||
void setSymbolicUnknownValue(SymbolicVariable const& _variable, SolverInterface& _interface);
|
void setSymbolicUnknownValue(SymbolicVariable const& _variable, EncodingContext& _context);
|
||||||
void setSymbolicUnknownValue(Expression _expr, solidity::TypePointer const& _type, SolverInterface& _interface);
|
void setSymbolicUnknownValue(Expression _expr, solidity::TypePointer const& _type, EncodingContext& _context);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,11 +28,11 @@ using namespace dev::solidity::smt;
|
|||||||
SymbolicVariable::SymbolicVariable(
|
SymbolicVariable::SymbolicVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
m_type(move(_type)),
|
m_type(move(_type)),
|
||||||
m_uniqueName(move(_uniqueName)),
|
m_uniqueName(move(_uniqueName)),
|
||||||
m_interface(_interface),
|
m_context(_context),
|
||||||
m_ssa(make_unique<SSAVariable>())
|
m_ssa(make_unique<SSAVariable>())
|
||||||
{
|
{
|
||||||
solAssert(m_type, "");
|
solAssert(m_type, "");
|
||||||
@ -43,11 +43,11 @@ SymbolicVariable::SymbolicVariable(
|
|||||||
SymbolicVariable::SymbolicVariable(
|
SymbolicVariable::SymbolicVariable(
|
||||||
SortPointer _sort,
|
SortPointer _sort,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
m_sort(move(_sort)),
|
m_sort(move(_sort)),
|
||||||
m_uniqueName(move(_uniqueName)),
|
m_uniqueName(move(_uniqueName)),
|
||||||
m_interface(_interface),
|
m_context(_context),
|
||||||
m_ssa(make_unique<SSAVariable>())
|
m_ssa(make_unique<SSAVariable>())
|
||||||
{
|
{
|
||||||
solAssert(m_sort, "");
|
solAssert(m_sort, "");
|
||||||
@ -65,7 +65,7 @@ string SymbolicVariable::currentName() const
|
|||||||
|
|
||||||
Expression SymbolicVariable::valueAtIndex(int _index) const
|
Expression SymbolicVariable::valueAtIndex(int _index) const
|
||||||
{
|
{
|
||||||
return m_interface.newVariable(uniqueSymbol(_index), m_sort);
|
return m_context.newVariable(uniqueSymbol(_index), m_sort);
|
||||||
}
|
}
|
||||||
|
|
||||||
string SymbolicVariable::uniqueSymbol(unsigned _index) const
|
string SymbolicVariable::uniqueSymbol(unsigned _index) const
|
||||||
@ -82,9 +82,9 @@ Expression SymbolicVariable::increaseIndex()
|
|||||||
SymbolicBoolVariable::SymbolicBoolVariable(
|
SymbolicBoolVariable::SymbolicBoolVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface)
|
SymbolicVariable(move(_type), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
solAssert(m_type->category() == solidity::Type::Category::Bool, "");
|
solAssert(m_type->category() == solidity::Type::Category::Bool, "");
|
||||||
}
|
}
|
||||||
@ -92,44 +92,44 @@ SymbolicBoolVariable::SymbolicBoolVariable(
|
|||||||
SymbolicIntVariable::SymbolicIntVariable(
|
SymbolicIntVariable::SymbolicIntVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface)
|
SymbolicVariable(move(_type), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
solAssert(isNumber(m_type->category()), "");
|
solAssert(isNumber(m_type->category()), "");
|
||||||
}
|
}
|
||||||
|
|
||||||
SymbolicAddressVariable::SymbolicAddressVariable(
|
SymbolicAddressVariable::SymbolicAddressVariable(
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicIntVariable(TypeProvider::uint(160), move(_uniqueName), _interface)
|
SymbolicIntVariable(TypeProvider::uint(160), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
SymbolicFixedBytesVariable::SymbolicFixedBytesVariable(
|
SymbolicFixedBytesVariable::SymbolicFixedBytesVariable(
|
||||||
unsigned _numBytes,
|
unsigned _numBytes,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicIntVariable(TypeProvider::uint(_numBytes * 8), move(_uniqueName), _interface)
|
SymbolicIntVariable(TypeProvider::uint(_numBytes * 8), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
SymbolicFunctionVariable::SymbolicFunctionVariable(
|
SymbolicFunctionVariable::SymbolicFunctionVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface),
|
SymbolicVariable(move(_type), move(_uniqueName), _context),
|
||||||
m_declaration(m_interface.newVariable(currentName(), m_sort))
|
m_declaration(m_context.newVariable(currentName(), m_sort))
|
||||||
{
|
{
|
||||||
solAssert(m_type->category() == solidity::Type::Category::Function, "");
|
solAssert(m_type->category() == solidity::Type::Category::Function, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
void SymbolicFunctionVariable::resetDeclaration()
|
void SymbolicFunctionVariable::resetDeclaration()
|
||||||
{
|
{
|
||||||
m_declaration = m_interface.newVariable(currentName(), m_sort);
|
m_declaration = m_context.newVariable(currentName(), m_sort);
|
||||||
}
|
}
|
||||||
|
|
||||||
Expression SymbolicFunctionVariable::increaseIndex()
|
Expression SymbolicFunctionVariable::increaseIndex()
|
||||||
@ -147,9 +147,9 @@ Expression SymbolicFunctionVariable::operator()(vector<Expression> _arguments) c
|
|||||||
SymbolicMappingVariable::SymbolicMappingVariable(
|
SymbolicMappingVariable::SymbolicMappingVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface)
|
SymbolicVariable(move(_type), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
solAssert(isMapping(m_type->category()), "");
|
solAssert(isMapping(m_type->category()), "");
|
||||||
}
|
}
|
||||||
@ -157,9 +157,9 @@ SymbolicMappingVariable::SymbolicMappingVariable(
|
|||||||
SymbolicArrayVariable::SymbolicArrayVariable(
|
SymbolicArrayVariable::SymbolicArrayVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface)
|
SymbolicVariable(move(_type), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
solAssert(isArray(m_type->category()), "");
|
solAssert(isArray(m_type->category()), "");
|
||||||
}
|
}
|
||||||
@ -167,9 +167,9 @@ SymbolicArrayVariable::SymbolicArrayVariable(
|
|||||||
SymbolicEnumVariable::SymbolicEnumVariable(
|
SymbolicEnumVariable::SymbolicEnumVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface)
|
SymbolicVariable(move(_type), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
solAssert(isEnum(m_type->category()), "");
|
solAssert(isEnum(m_type->category()), "");
|
||||||
}
|
}
|
||||||
@ -177,9 +177,9 @@ SymbolicEnumVariable::SymbolicEnumVariable(
|
|||||||
SymbolicTupleVariable::SymbolicTupleVariable(
|
SymbolicTupleVariable::SymbolicTupleVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
string _uniqueName,
|
string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
):
|
):
|
||||||
SymbolicVariable(move(_type), move(_uniqueName), _interface)
|
SymbolicVariable(move(_type), move(_uniqueName), _context)
|
||||||
{
|
{
|
||||||
solAssert(isTuple(m_type->category()), "");
|
solAssert(isTuple(m_type->category()), "");
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,7 @@ namespace solidity
|
|||||||
namespace smt
|
namespace smt
|
||||||
{
|
{
|
||||||
|
|
||||||
|
class EncodingContext;
|
||||||
class Type;
|
class Type;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -40,12 +41,12 @@ public:
|
|||||||
SymbolicVariable(
|
SymbolicVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
SymbolicVariable(
|
SymbolicVariable(
|
||||||
SortPointer _sort,
|
SortPointer _sort,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
|
|
||||||
virtual ~SymbolicVariable() = default;
|
virtual ~SymbolicVariable() = default;
|
||||||
@ -72,7 +73,7 @@ protected:
|
|||||||
/// Solidity type, used for size and range in number types.
|
/// Solidity type, used for size and range in number types.
|
||||||
solidity::TypePointer m_type;
|
solidity::TypePointer m_type;
|
||||||
std::string m_uniqueName;
|
std::string m_uniqueName;
|
||||||
SolverInterface& m_interface;
|
EncodingContext& m_context;
|
||||||
std::unique_ptr<SSAVariable> m_ssa;
|
std::unique_ptr<SSAVariable> m_ssa;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -85,7 +86,7 @@ public:
|
|||||||
SymbolicBoolVariable(
|
SymbolicBoolVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -98,7 +99,7 @@ public:
|
|||||||
SymbolicIntVariable(
|
SymbolicIntVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -110,7 +111,7 @@ class SymbolicAddressVariable: public SymbolicIntVariable
|
|||||||
public:
|
public:
|
||||||
SymbolicAddressVariable(
|
SymbolicAddressVariable(
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -123,7 +124,7 @@ public:
|
|||||||
SymbolicFixedBytesVariable(
|
SymbolicFixedBytesVariable(
|
||||||
unsigned _numBytes,
|
unsigned _numBytes,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -136,7 +137,7 @@ public:
|
|||||||
SymbolicFunctionVariable(
|
SymbolicFunctionVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
|
|
||||||
Expression increaseIndex();
|
Expression increaseIndex();
|
||||||
@ -159,7 +160,7 @@ public:
|
|||||||
SymbolicMappingVariable(
|
SymbolicMappingVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -172,7 +173,7 @@ public:
|
|||||||
SymbolicArrayVariable(
|
SymbolicArrayVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -185,7 +186,7 @@ public:
|
|||||||
SymbolicEnumVariable(
|
SymbolicEnumVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -198,7 +199,7 @@ public:
|
|||||||
SymbolicTupleVariable(
|
SymbolicTupleVariable(
|
||||||
solidity::TypePointer _type,
|
solidity::TypePointer _type,
|
||||||
std::string _uniqueName,
|
std::string _uniqueName,
|
||||||
SolverInterface& _interface
|
EncodingContext& _context
|
||||||
);
|
);
|
||||||
|
|
||||||
std::vector<std::shared_ptr<SymbolicVariable>> const& components()
|
std::vector<std::shared_ptr<SymbolicVariable>> const& components()
|
||||||
|
@ -3,9 +3,9 @@
|
|||||||
{
|
{
|
||||||
"smtlib2responses":
|
"smtlib2responses":
|
||||||
{
|
{
|
||||||
"0x399638a49c613bd393612f518a0bc22e9c7801791f0fa10a760b53c88686763c": "unsat\n",
|
"0x68fa399769cf119cbe46d5ae578164d39ea67e06eee08eeb37042d08a13a0cd8": "unsat\n",
|
||||||
"0x91c1bd0064608eae1120536e6e62864766bc370782e162d70f05d94a9f184ffc": "sat\n((|EVALEXPR_0| 1))\n",
|
"0xd78cd71ff120c5b5ecc5020146952f62de0506c4baef7ba499239a2ce2b14343": "sat\n((|EVALEXPR_0| 0))\n",
|
||||||
"0x980a3db3305233a5417ea16e6253211d98818fcaa2ce7d0858f95080160092ef": "sat\n((|EVALEXPR_0| 0))\n"
|
"0xf74672131cc6b7b3d6b82ed2fa0da2b75d01c9bc32f15d2f77e8e39e174f5a37": "sat\n((|EVALEXPR_0| 1))\n"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
{
|
{
|
||||||
"smtlib2responses":
|
"smtlib2responses":
|
||||||
{
|
{
|
||||||
"0xc1ec66473d8e3b43cd320f847166c54f779e5e905085a837418d211233144dab": "sat\n((|EVALEXPR_0| 0))\n"
|
"0x9e377366ae857502a72974bd4e563258a29fa84dd4358cc053057544409da0ea": "sat\n((|EVALEXPR_0| 0))\n"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user