diff options
author | Dejan Jovanović <dejan.jovanovic@gmail.com> | 2011-07-05 16:21:50 +0000 |
---|---|---|
committer | Dejan Jovanović <dejan.jovanovic@gmail.com> | 2011-07-05 16:21:50 +0000 |
commit | 7342d1ca87397f3d5beb2c04b819243303e69a7c (patch) | |
tree | 9e166f1884275be7d4b33b13b8bcfe9418e61033 /src/prop/cnf_stream.cpp | |
parent | af25c3f8498198dd6dd114c3b4ef39af54611e1e (diff) |
updated preprocessing and rewriting input equalities into inequalities for LRA
Diffstat (limited to 'src/prop/cnf_stream.cpp')
-rw-r--r-- | src/prop/cnf_stream.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/src/prop/cnf_stream.cpp b/src/prop/cnf_stream.cpp index 6732b09bc..0967f54ff 100644 --- a/src/prop/cnf_stream.cpp +++ b/src/prop/cnf_stream.cpp @@ -121,15 +121,16 @@ SatLiteral CnfStream::newLiteral(TNode node, bool theoryLiteral) { d_nodeCache[~lit] = node.notNode(); } + // If a theory literal, we pre-register it + if (theoryLiteral) { + bool backup = d_assertingLemma; + d_registrar.preRegister(node); + d_assertingLemma = backup; + } + // Here, you can have it Debug("cnf") << "newLiteral(" << node << ") => " << lit << endl; - // have to keep track of this, because with the call to preRegister(), - // the cnf stream is re-entrant! - bool wasAssertingLemma = d_assertingLemma; - d_registrar.preRegister(node); - d_assertingLemma = wasAssertingLemma; - return lit; } |