clarified signature: support partial read_proof to accommodate proof term normalization vs. approximative proof_boxes as upper bound;
authorwenzelm
Fri, 18 Oct 2019 16:25:54 +0200
changeset 70899 5f6dea6a7a4c
parent 70898 c13d9d3ee128
child 70900 954e7f79c25a
child 70904 caf91f9b847b
clarified signature: support partial read_proof to accommodate proof term normalization vs. approximative proof_boxes as upper bound;
src/Pure/Thy/export_theory.scala
--- a/src/Pure/Thy/export_theory.scala	Thu Oct 17 21:52:16 2019 +0200
+++ b/src/Pure/Thy/export_theory.scala	Fri Oct 18 16:25:54 2019 +0200
@@ -167,7 +167,8 @@
   def read_pure_theory(store: Sessions.Store, cache: Option[Term.Cache] = None): Theory =
     read_pure(store, read_theory(_, _, _, cache = cache))
 
-  def read_pure_proof(store: Sessions.Store, id: Thm_Id, cache: Option[Term.Cache] = None): Proof =
+  def read_pure_proof(
+      store: Sessions.Store, id: Thm_Id, cache: Option[Term.Cache] = None): Option[Proof] =
     read_pure(store, (provider, _, _) => read_proof(provider, id, cache = cache))
 
 
@@ -398,23 +399,25 @@
         cache.proof(proof))
   }
 
-  def read_proof(provider: Export.Provider, id: Thm_Id, cache: Option[Term.Cache] = None): Proof =
+  def read_proof(
+    provider: Export.Provider, id: Thm_Id, cache: Option[Term.Cache] = None): Option[Proof] =
   {
-    val body = provider.focus(id.theory_name).uncompressed_yxml(export_prefix_proofs + id.serial)
-    if (body.isEmpty) error("Bad proof export " + id.serial)
+    for { entry <- provider.focus(id.theory_name)(export_prefix_proofs + id.serial) }
+    yield {
+      val body = entry.uncompressed_yxml()
+      val (typargs, (args, (prop_body, proof_body))) =
+      {
+        import XML.Decode._
+        import Term_XML.Decode._
+        pair(list(pair(string, sort)), pair(list(pair(string, typ)), pair(x => x, x => x)))(body)
+      }
+      val env = args.toMap
+      val prop = Term_XML.Decode.term_env(env)(prop_body)
+      val proof = Term_XML.Decode.proof_env(env)(proof_body)
 
-    val (typargs, (args, (prop_body, proof_body))) =
-    {
-      import XML.Decode._
-      import Term_XML.Decode._
-      pair(list(pair(string, sort)), pair(list(pair(string, typ)), pair(x => x, x => x)))(body)
+      val result = Proof(typargs, args, prop, proof)
+      cache.map(result.cache(_)) getOrElse result
     }
-    val env = args.toMap
-    val prop = Term_XML.Decode.term_env(env)(prop_body)
-    val proof = Term_XML.Decode.proof_env(env)(proof_body)
-
-    val result = Proof(typargs, args, prop, proof)
-    cache.map(result.cache(_)) getOrElse result
   }