Add support for --dump-models option, in preparation for casc.
authorAndrew Reynolds <andrew.j.reynolds@gmail.com>
Fri, 17 May 2013 22:40:34 +0000 (17:40 -0500)
committerAndrew Reynolds <andrew.j.reynolds@gmail.com>
Fri, 17 May 2013 22:40:40 +0000 (17:40 -0500)
src/main/command_executor.cpp
src/smt/options

index f1742b5497194a8436e81e2cac708fe978c28f3f..556e51216b4f1981ac1af0ebd420987d86a7763c 100644 (file)
@@ -19,6 +19,8 @@
 
 #include "main/main.h"
 
+#include "smt/options.h"
+
 namespace CVC4 {
 namespace main {
 
@@ -64,6 +66,17 @@ bool CommandExecutor::doCommandSingleton(Command *cmd)
   } else {
     status = smtEngineInvoke(&d_smtEngine, cmd, NULL);
   }
+  //dump the model if option is set
+  if(status && d_options[options::produceModels] && d_options[options::dumpModels]) {
+    CheckSatCommand *cs = dynamic_cast<CheckSatCommand*>(cmd);
+    if(cs != NULL) {
+      if(cs->getResult().asSatisfiabilityResult().isSat() == Result::SAT ||
+         (cs->getResult().isUnknown() && cs->getResult().whyUnknown() == Result::INCOMPLETE) ){
+        Command * gm = new GetModelCommand;
+        status = doCommandSingleton(gm);
+      }
+    }
+  }
   return status;
 }
 
index 2680f4105106693e92dc2adcdd7910d07fdc3755..e5f9c2eaf1d779806219e8d8fd135dfd343fcb4e 100644 (file)
@@ -24,6 +24,8 @@ common-option produceModels produce-models -m --produce-models bool :default fal
  support the get-value and get-model commands
 option checkModels check-models --check-models bool :predicate CVC4::smt::beforeSearch :predicate-include "smt/options_handlers.h"
  after SAT/INVALID/UNKNOWN, check that the generated model satisfies user assertions
+option dumpModels --dump-models bool :default false
+ output models after every SAT/INVALID/UNKNOWN response
 option proof produce-proofs --proof bool :default false :predicate CVC4::smt::proofEnabledBuild CVC4::smt::beforeSearch :predicate-include "smt/options_handlers.h"
  turn on proof generation
 # this is just a placeholder for later; it doesn't show up in command-line options listings