A way to call the ATP linkup from ML scripts
authorpaulson
Tue, 10 Oct 2006 15:33:25 +0200
changeset 20954 3bbe7cab8037
parent 20953 1ea394dc2a0f
child 20955 65a9a30b8ece
A way to call the ATP linkup from ML scripts
src/HOL/Tools/res_atp.ML
--- a/src/HOL/Tools/res_atp.ML	Tue Oct 10 15:30:48 2006 +0200
+++ b/src/HOL/Tools/res_atp.ML	Tue Oct 10 15:33:25 2006 +0200
@@ -5,7 +5,7 @@
 ATPs with TPTP format input.
 *)
 
-(*FIXME: Do we need this signature?*)
+(*Currently unused, during debugging*)
 signature RES_ATP =
 sig
   val prover: string ref
@@ -829,8 +829,7 @@
 
 (*writes out the current clasimpset to a tptp file;
   turns off xsymbol at start of function, restoring it at end    *)
-val isar_atp = setmp print_mode [] 
- (fn (ctxt, th) =>
+fun isar_atp_body (ctxt, th) =
   if Thm.no_prems th then ()
   else
     let
@@ -842,7 +841,15 @@
       Output.debug ("problem files: " ^ space_implode ", " files); 
       Output.debug ("pid: " ^ string_of_pid pid);
       watcher_call_provers (sign_of_thm th) (Thm.prems_of th) (childin, childout, pid)
-    end);
+    end;
+
+val isar_atp = setmp print_mode [] isar_atp_body;
+
+(*For ML scripts, and primarily, for debugging*)
+fun callatp () = 
+  let val th = topthm()
+      val ctxt = ProofContext.init (theory_of_thm th)
+  in  isar_atp_body (ctxt, th)  end;
 
 val isar_atp_writeonly = setmp print_mode [] 
       (fn (ctxt,th) =>