clarified store_proof: before attributes are applied, to ensure proper thm_proof boxes for declaration attributes;
authorwenzelm
Wed, 27 Dec 2023 21:42:42 +0100
changeset 79378 664d378c18bc
parent 79377 c5282516e2d5
child 79379 e31b48b47e88
clarified store_proof: before attributes are applied, to ensure proper thm_proof boxes for declaration attributes;
src/Pure/global_theory.ML
--- a/src/Pure/global_theory.ML	Wed Dec 27 20:52:33 2023 +0100
+++ b/src/Pure/global_theory.ML	Wed Dec 27 21:42:42 2023 +0100
@@ -214,6 +214,12 @@
 fun zproof_enabled {zproof} name =
   name <> "" andalso zproof andalso Proofterm.zproof_enabled (Proofterm.get_proofs_level ());
 
+fun store_proof zproof (name, thm) thy =
+  if zproof_enabled zproof (#1 (#1 name)) then
+    let val (thm', thy') = Thm.store_zproof name thm thy
+    in ((name, thm'), thy') end
+  else ((name, thm), thy);
+
 fun store_proofs_lazy zproof name thms thy =
   if zproof_enabled zproof (#1 name) then
     fold_map (uncurry Thm.store_zproof) (Thm_Name.list name (Lazy.force thms)) thy
@@ -307,6 +313,10 @@
   let
     val name = Sign.full_name_pos thy b;
     val named_facts = Thm_Name.expr name facts;
+    val (named_facts', thy') =
+      (named_facts, thy) |-> fold_map (fn (thms, atts) => fn thy1 =>
+        let val (thms', thy2) = fold_map (store_proof zproof) thms thy1
+        in ((thms', atts), thy2) end);
 
     val unnamed = #1 name = "";
     val name_thm1 = if unnamed then #2 else uncurry (name_thm_short name_flags1);
@@ -315,12 +325,12 @@
       fold_maps (fn (named_thms, atts) => fn thy =>
         let val thms = map name_thm1 named_thms
         in fold_map (Thm.theory_attributes atts o Thm.transfer thy) thms thy end);
-    val register = register_proofs zproof name;
+    val register = register_proofs {zproof = false} name;
   in
-    if unnamed then app_facts named_facts thy |-> register
+    if unnamed then app_facts named_facts' thy' |-> register
     else
       let
-        val (thms', thy') = app_facts named_facts thy |>> name_thms name_flags2 name |-> register;
+        val (thms', thy') = app_facts named_facts' thy' |>> name_thms name_flags2 name |-> register;
         val thy'' = thy' |> add_facts (b, Lazy.value thms');
       in (map (Thm.transfer thy'') thms', thy'') end
   end;