aboutsummaryrefslogtreecommitdiffstats
path: root/libsolidity/formal/SolverInterface.h
diff options
context:
space:
mode:
authorAlex Beregszaszi <alex@rtfs.hu>2018-07-28 00:07:56 +0800
committerGitHub <noreply@github.com>2018-07-28 00:07:56 +0800
commit2794a22d84d05c83bd6e9f57d16a9e66a662812f (patch)
treec861a097b885416b67d2ef98f20ae9f91950756d /libsolidity/formal/SolverInterface.h
parent5faa60e8834b5302f8d58f719c6962ed3affb50f (diff)
parent55c1fb60b4ba60685262f332f2b197a7ef81d5b8 (diff)
downloaddexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.tar
dexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.tar.gz
dexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.tar.bz2
dexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.tar.lz
dexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.tar.xz
dexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.tar.zst
dexon-solidity-2794a22d84d05c83bd6e9f57d16a9e66a662812f.zip
Merge pull request #4351 from ethereum/smt_portfolio
[SMTChecker] SMTPortfolio: use all SMT solvers available
Diffstat (limited to 'libsolidity/formal/SolverInterface.h')
-rw-r--r--libsolidity/formal/SolverInterface.h14
1 files changed, 10 insertions, 4 deletions
diff --git a/libsolidity/formal/SolverInterface.h b/libsolidity/formal/SolverInterface.h
index a6d65ce2..8bbd0417 100644
--- a/libsolidity/formal/SolverInterface.h
+++ b/libsolidity/formal/SolverInterface.h
@@ -39,7 +39,7 @@ namespace smt
enum class CheckResult
{
- SATISFIABLE, UNSATISFIABLE, UNKNOWN, ERROR
+ SATISFIABLE, UNSATISFIABLE, UNKNOWN, CONFLICTING, ERROR
};
enum class Sort
@@ -199,8 +199,10 @@ public:
virtual void push() = 0;
virtual void pop() = 0;
- virtual Expression newFunction(std::string _name, Sort _domain, Sort _codomain)
+ virtual void declareFunction(std::string _name, Sort _domain, Sort _codomain) = 0;
+ Expression newFunction(std::string _name, Sort _domain, Sort _codomain)
{
+ declareFunction(_name, _domain, _codomain);
solAssert(_domain == Sort::Int, "Function sort not supported.");
// Subclasses should do something here
switch (_codomain)
@@ -214,14 +216,18 @@ public:
break;
}
}
- virtual Expression newInteger(std::string _name)
+ virtual void declareInteger(std::string _name) = 0;
+ Expression newInteger(std::string _name)
{
// Subclasses should do something here
+ declareInteger(_name);
return Expression(std::move(_name), {}, Sort::Int);
}
- virtual Expression newBool(std::string _name)
+ virtual void declareBool(std::string _name) = 0;
+ Expression newBool(std::string _name)
{
// Subclasses should do something here
+ declareBool(_name);
return Expression(std::move(_name), {}, Sort::Bool);
}