diff options
author | Morgan Deters <mdeters@gmail.com> | 2012-02-23 23:08:03 +0000 |
---|---|---|
committer | Morgan Deters <mdeters@gmail.com> | 2012-02-23 23:08:03 +0000 |
commit | 5a20a19a30929ad58a9e64a9d8d1f877f3a07ae6 (patch) | |
tree | 2a800e6b1d6773e1c844767f5daed51148b5660b /src/theory/theory_engine.cpp | |
parent | 1f2590541aa60f4b62b7c96659362ee4431d2d63 (diff) |
Added ability to set a "cvc4-specific logic" in standards-compliant
SMT-LIBv1 and SMT-LIBv2 input:
In SMT-LIBv1, you specify the "cvc4_logic" benchmark attribute; for instance:
(benchmark actually_a_sat_benchmark_but_looks_like_uf
:logic QF_UF
:cvc4_logic { QF_SAT }
[...]
In SMT-LIBv2, you use a set-info; for instance:
(set-logic QF_UF)
(set-info :cvc4-logic "QF_SAT")
[...]
Right now, the only thing this does is disable the symmetry breaker for
benchmarks like the above ones.
As part of this work, TheoryEngine::setLogic() was removed (the logic field there
wasn't actually used anywhere, its need disappeared when
Theory::setUninterpretedSortOwner() was provided).
Also, Theory::d_uninterpretedSortOwner got a name change to
Theory::s_uninterpretedSortOwner, to highlight that it is static to the Theory
class. This represents a breakage of our separation goals for CVC4, since it
means that two SmtEngines cannot be created separately to solve a QF_AX and
QF_UF problem. A bug report is pending.
Diffstat (limited to 'src/theory/theory_engine.cpp')
-rw-r--r-- | src/theory/theory_engine.cpp | 7 |
1 files changed, 0 insertions, 7 deletions
diff --git a/src/theory/theory_engine.cpp b/src/theory/theory_engine.cpp index c4a8dc591..3486d9075 100644 --- a/src/theory/theory_engine.cpp +++ b/src/theory/theory_engine.cpp @@ -52,7 +52,6 @@ TheoryEngine::TheoryEngine(context::Context* context, d_hasShutDown(false), d_incomplete(context, false), d_sharedAssertions(context), - d_logic(""), d_propagatedLiterals(context), d_propagatedLiteralsIndex(context, 0), d_decisionRequests(context), @@ -78,12 +77,6 @@ TheoryEngine::~TheoryEngine() { } } -void TheoryEngine::setLogic(std::string logic) { - Assert(d_logic.empty()); - // Set the logic - d_logic = logic; -} - void TheoryEngine::preRegister(TNode preprocessed) { if(Dump.isOn("missed-t-propagations")) { d_possiblePropagations.push_back(preprocessed); |