diff options
author | Dan Liew <daniel.liew@imperial.ac.uk> | 2016-01-07 09:50:39 +0000 |
---|---|---|
committer | Dan Liew <daniel.liew@imperial.ac.uk> | 2016-01-12 11:40:34 +0000 |
commit | 4bb6a5850980ef29a88a9cfe3c6c6e06e1f7df9d (patch) | |
tree | 1b66e43e21736b307871c6d25bff3a6d5d1f2c9c | |
parent | 0784ff823bdf8cf52eb08ecae2987d9a79b7f45b (diff) | |
download | klee-4bb6a5850980ef29a88a9cfe3c6c6e06e1f7df9d.tar.gz |
[NFC] Refactor DummySolver out of Solver.cpp into its own file
``DummySolver.cpp``. Whilst I'm here also clang-format the modified code.
-rw-r--r-- | lib/Solver/DummySolver.cpp | 63 | ||||
-rw-r--r-- | lib/Solver/Solver.cpp | 40 |
2 files changed, 63 insertions, 40 deletions
diff --git a/lib/Solver/DummySolver.cpp b/lib/Solver/DummySolver.cpp new file mode 100644 index 00000000..39328653 --- /dev/null +++ b/lib/Solver/DummySolver.cpp @@ -0,0 +1,63 @@ +//===-- DummySolver.cpp ---------------------------------------------------===// +// +// The KLEE Symbolic Virtual Machine +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "klee/Solver.h" +#include "klee/SolverImpl.h" +#include "klee/SolverStats.h" + +namespace klee { + +class DummySolverImpl : public SolverImpl { +public: + DummySolverImpl(); + + bool computeValidity(const Query &, Solver::Validity &result); + bool computeTruth(const Query &, bool &isValid); + bool computeValue(const Query &, ref<Expr> &result); + bool computeInitialValues(const Query &, + const std::vector<const Array *> &objects, + std::vector<std::vector<unsigned char> > &values, + bool &hasSolution); + SolverRunStatus getOperationStatusCode(); +}; + +DummySolverImpl::DummySolverImpl() {} + +bool DummySolverImpl::computeValidity(const Query &, Solver::Validity &result) { + ++stats::queries; + // FIXME: We should have stats::queriesFail; + return false; +} + +bool DummySolverImpl::computeTruth(const Query &, bool &isValid) { + ++stats::queries; + // FIXME: We should have stats::queriesFail; + return false; +} + +bool DummySolverImpl::computeValue(const Query &, ref<Expr> &result) { + ++stats::queries; + ++stats::queryCounterexamples; + return false; +} + +bool DummySolverImpl::computeInitialValues( + const Query &, const std::vector<const Array *> &objects, + std::vector<std::vector<unsigned char> > &values, bool &hasSolution) { + ++stats::queries; + ++stats::queryCounterexamples; + return false; +} + +SolverImpl::SolverRunStatus DummySolverImpl::getOperationStatusCode() { + return SOLVER_RUN_STATUS_FAILURE; +} + +Solver *createDummySolver() { return new Solver(new DummySolverImpl()); } +} diff --git a/lib/Solver/Solver.cpp b/lib/Solver/Solver.cpp index e596d37d..07e8b8a0 100644 --- a/lib/Solver/Solver.cpp +++ b/lib/Solver/Solver.cpp @@ -276,46 +276,6 @@ std::pair< ref<Expr>, ref<Expr> > Solver::getRange(const Query& query) { ConstantExpr::create(max, width)); } - -/***/ - -class DummySolverImpl : public SolverImpl { -public: - DummySolverImpl() {} - - bool computeValidity(const Query&, Solver::Validity &result) { - ++stats::queries; - // FIXME: We should have stats::queriesFail; - return false; - } - bool computeTruth(const Query&, bool &isValid) { - ++stats::queries; - // FIXME: We should have stats::queriesFail; - return false; - } - bool computeValue(const Query&, ref<Expr> &result) { - ++stats::queries; - ++stats::queryCounterexamples; - return false; - } - bool computeInitialValues(const Query&, - const std::vector<const Array*> &objects, - std::vector< std::vector<unsigned char> > &values, - bool &hasSolution) { - ++stats::queries; - ++stats::queryCounterexamples; - return false; - } - SolverRunStatus getOperationStatusCode() { - return SOLVER_RUN_STATUS_FAILURE; - } - -}; - -Solver *klee::createDummySolver() { - return new Solver(new DummySolverImpl()); -} - /***/ class STPSolverImpl : public SolverImpl { |