aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorckeller <ckeller@users.noreply.github.com>2020-03-26 12:14:05 +0100
committerGitHub <noreply@github.com>2020-03-26 12:14:05 +0100
commit80a54a0e1974729d4756d2cc8483a2548c8dd2d0 (patch)
tree311cf5b94deed4a193cb7dd05247846e5cba06ef /src
parenta3146935a48337634f6810d53a7cc7302cb61d47 (diff)
downloadsmtcoq-80a54a0e1974729d4756d2cc8483a2548c8dd2d0.tar.gz
smtcoq-80a54a0e1974729d4756d2cc8483a2548c8dd2d0.zip
Test asynchronous and make the selected lemmas persistant (#66)
* Add a test target for asynchronous proof checking (does not fully reflect the coqide behavior though) * Make the selected lemmas persistant Co-authored-by: Chantal Keller <Chantal.Keller@lri.fr>
Diffstat (limited to 'src')
-rw-r--r--src/versions/standard/Makefile.local3
-rw-r--r--src/versions/standard/g_smtcoq_standard.ml430
2 files changed, 28 insertions, 5 deletions
diff --git a/src/versions/standard/Makefile.local b/src/versions/standard/Makefile.local
index 089ae9a..8abc72c 100644
--- a/src/versions/standard/Makefile.local
+++ b/src/versions/standard/Makefile.local
@@ -16,6 +16,9 @@ vtest :
lfsctest :
cd ../unit-tests; make cleanvo; make lfsc
+paralleltest :
+ cd ../unit-tests; make parallel
+
clean::
cd ../unit-tests; make clean
diff --git a/src/versions/standard/g_smtcoq_standard.ml4 b/src/versions/standard/g_smtcoq_standard.ml4
index bf923cc..6c3b8cf 100644
--- a/src/versions/standard/g_smtcoq_standard.ml4
+++ b/src/versions/standard/g_smtcoq_standard.ml4
@@ -80,17 +80,37 @@ TACTIC EXTEND Tactic_zchaff
| [ "zchaff_bool_no_check" ] -> [ Zchaff.tactic_no_check () ]
END
-let lemmas_list = ref []
+let lemmas_list = Summary.ref ~name:"Selected lemmas" []
+
+let cache_lemmas (_, lems) =
+ lemmas_list := lems
+
+let declare_lemmas : Structures.constr_expr list -> Libobject.obj =
+ let open Libobject in
+ declare_object
+ {
+ (default_object "LEMMAS") with
+ cache_function = cache_lemmas;
+ load_function = (fun _ -> cache_lemmas);
+ }
+
+let add_lemmas lems =
+ Lib.add_anonymous_leaf (declare_lemmas (lems @ !lemmas_list))
+
+let clear_lemmas () =
+ Lib.add_anonymous_leaf (declare_lemmas [])
+
+let get_lemmas () = !lemmas_list
VERNAC COMMAND EXTEND Add_lemma CLASSIFIED AS SIDEFF
-| [ "Add_lemmas" constr_list(lems) ] -> [ lemmas_list := lems @ !lemmas_list ]
-| [ "Clear_lemmas" ] -> [ lemmas_list := [] ]
+| [ "Add_lemmas" constr_list(lems) ] -> [ add_lemmas lems ]
+| [ "Clear_lemmas" ] -> [ clear_lemmas () ]
END
TACTIC EXTEND Tactic_verit
-| [ "verit_bool_base" constr_list(lpl) ] -> [ Verit.tactic (List.map EConstr.Unsafe.to_constr lpl) !lemmas_list ]
-| [ "verit_bool_no_check_base" constr_list(lpl) ] -> [ Verit.tactic_no_check (List.map EConstr.Unsafe.to_constr lpl) !lemmas_list ]
+| [ "verit_bool_base" constr_list(lpl) ] -> [ Verit.tactic (List.map EConstr.Unsafe.to_constr lpl) (get_lemmas ()) ]
+| [ "verit_bool_no_check_base" constr_list(lpl) ] -> [ Verit.tactic_no_check (List.map EConstr.Unsafe.to_constr lpl) (get_lemmas ()) ]
END
TACTIC EXTEND Tactic_cvc4