clarified signature: more explicit get_proofs_level with bounds check;
authorwenzelm
Sat, 09 Dec 2023 17:31:10 +0100
changeset 79219 8b371e684acf
parent 79218 8857975b99a9
child 79220 f9d972b464c1
clarified signature: more explicit get_proofs_level with bounds check;
src/Pure/proofterm.ML
src/Pure/thm.ML
--- a/src/Pure/proofterm.ML	Fri Dec 08 20:56:21 2023 +0100
+++ b/src/Pure/proofterm.ML	Sat Dec 09 17:31:10 2023 +0100
@@ -82,6 +82,8 @@
   (*primitive operations*)
   val proof_enabled: int -> bool
   val zproof_enabled: int -> bool
+  val oracle_enabled: int -> bool
+  val get_proofs_level: unit -> int
   val proofs: int Unsynchronized.ref
   val any_proofs_enabled: unit -> bool
   val atomic_proof: proof -> bool
@@ -486,11 +488,18 @@
 
 (** proof objects with different levels of detail **)
 
-fun proof_enabled proofs = Word.andb (Word.fromInt proofs, 0w2) <> 0w0;
-fun zproof_enabled proofs = Word.andb (Word.fromInt proofs, 0w4) <> 0w0;
+fun proof_enabled proofs = proofs = 2 orelse proofs = 6;
+fun zproof_enabled proofs = proofs = 4 orelse proofs = 5 orelse proofs = 6;
+fun oracle_enabled proofs = not (proofs = 0 orelse proofs = 4);
 
 val proofs = Unsynchronized.ref 6;
 
+fun get_proofs_level () =
+  let val proofs = ! proofs in
+    if 0 <= proofs andalso proofs <= 6 andalso proofs <> 3 then proofs
+    else error ("Illegal level of detail for proof objects: " ^ string_of_int proofs)
+  end;
+
 fun any_proofs_enabled () =
   let val proofs = ! proofs
   in proof_enabled proofs orelse zproof_enabled proofs end;
@@ -2192,7 +2201,7 @@
     val (ucontext, prop1) = Logic.unconstrainT shyps prop;
 
     val PBody {oracles = oracles0, thms = thms0, zboxes = zboxes0, proof = (prf, zprf)} = body;
-    val proofs = ! proofs;
+    val proofs = get_proofs_level ();
     val prf' = if proof_enabled proofs then fold_rev implies_intr_proof hyps prf else MinProof;
     val zprf' = if zproof_enabled proofs then ZTerm.todo_proof zprf else ZDummy;
     val body0 = PBody {oracles = oracles0, thms = thms0, zboxes = zboxes0, proof = (prf', zprf')};
--- a/src/Pure/thm.ML	Fri Dec 08 20:56:21 2023 +0100
+++ b/src/Pure/thm.ML	Sat Dec 09 17:31:10 2023 +0100
@@ -755,9 +755,6 @@
 
 val promise_ord: (serial * thm future) ord = fn ((i, _), (j, _)) => int_ord (j, i);
 
-fun bad_proofs i =
-  error ("Illegal level of detail for proof objects: " ^ string_of_int i);
-
 fun deriv_rule2 (f, g)
     (Deriv {promises = ps1, body = body1}) (Deriv {promises = ps2, body = body2}) =
   let
@@ -769,21 +766,16 @@
     val oracles = Proofterm.union_oracles oracles1 oracles2;
     val thms = Proofterm.union_thms thms1 thms2;
     val zboxes = Proofterm.union_zboxes zboxes1 zboxes2;
-    val proof =
-      (case ! Proofterm.proofs of
-        0 => Proofterm.no_proof
-      | 1 => Proofterm.no_proof
-      | 2 => (f prf1 prf2, ZDummy)
-      | 4 => (MinProof, g zprf1 zprf2)
-      | 5 => (MinProof, g zprf1 zprf2)
-      | 6 => (f prf1 prf2, g zprf1 zprf2)
-      | i => bad_proofs i);
-  in make_deriv ps oracles thms zboxes proof end;
+
+    val proofs = Proofterm.get_proofs_level ();
+    val prf = if Proofterm.proof_enabled proofs then f prf1 prf2 else MinProof;
+    val zprf = if Proofterm.zproof_enabled proofs then g zprf1 zprf2 else ZDummy;
+  in make_deriv ps oracles thms zboxes (prf, zprf) end;
 
 fun deriv_rule1 (f, g) = deriv_rule2 (K f, K g) empty_deriv;
 
 fun deriv_rule0 (f, g) =
-  let val proofs = ! Proofterm.proofs in
+  let val proofs = Proofterm.get_proofs_level () in
     if Proofterm.proof_enabled proofs orelse Proofterm.zproof_enabled proofs then
       deriv_rule1 (I, I) (make_deriv [] [] [] Proofterm.empty_zboxes
        (if Proofterm.proof_enabled proofs then f () else MinProof,
@@ -1167,20 +1159,21 @@
         else
           let
             val cert = Context.join_certificate (Context.Certificate thy', cert2);
-            fun no_oracle () = ((name, Position.none), NONE);
-            fun make_oracle () = ((name, Position.thread_data ()), SOME prop);
-            fun zproof () = ZTerm.oracle_proof (Context.certificate_theory cert) name prop;
-            val (oracle, proof) =
-              (case ! Proofterm.proofs of
-                0 => (no_oracle (), Proofterm.no_proof)
-              | 1 => (make_oracle (), Proofterm.no_proof)
-              | 2 => (make_oracle (), (Proofterm.oracle_proof name prop, zproof ()))
-              | 4 => (no_oracle (), (MinProof, zproof ()))
-              | 5 => (make_oracle (), (MinProof, zproof ()))
-              | 6 => (make_oracle (), (Proofterm.oracle_proof name prop, zproof ()))
-              | i => bad_proofs i);
+            val proofs = Proofterm.get_proofs_level ();
+            val oracle =
+              if Proofterm.oracle_enabled proofs
+              then ((name, Position.thread_data ()), SOME prop)
+              else ((name, Position.none), NONE);
+            val proof =
+              if Proofterm.proof_enabled proofs
+              then Proofterm.oracle_proof name prop
+              else MinProof;
+            val zproof =
+              if Proofterm.zproof_enabled proofs
+              then ZTerm.oracle_proof (Context.certificate_theory cert) name prop
+              else ZDummy;
           in
-            Thm (make_deriv [] [oracle] [] Proofterm.empty_zboxes proof,
+            Thm (make_deriv [] [oracle] [] Proofterm.empty_zboxes (proof, zproof),
              {cert = cert,
               tags = [],
               maxidx = maxidx,