clarified signature: support shared cache;
authorwenzelm
Fri, 08 Dec 2023 18:39:58 +0100
changeset 79210 5ed6f16a5f7c
parent 79209 fe24edf8acda
child 79211 35ead2206eb1
clarified signature: support shared cache;
src/Pure/zterm.ML
--- a/src/Pure/zterm.ML	Fri Dec 08 16:01:42 2023 +0100
+++ b/src/Pure/zterm.ML	Fri Dec 08 18:39:58 2023 +0100
@@ -412,8 +412,6 @@
 
 (* beta normalization wrt. environment *)
 
-local
-
 fun norm_type_same ztyp tyenv =
   if Vartab.is_empty tyenv then Same.same
   else
@@ -462,29 +460,27 @@
         | norm _ = raise Same.SAME;
     in norm end;
 
-fun make_cache thy =
+fun norm_proof_same (cache as {ztyp, ...}) (envir as Envir.Envir {tyenv, ...}) =
+  if Envir.is_empty envir then Same.same
+  else map_proof_same (norm_type_same ztyp tyenv) (norm_term_same cache envir);
+
+fun norm_cache thy =
   let
     val {ztyp, zterm} = zterm_cache_consts (Sign.consts_of thy);
     val typ = typ_cache ();
   in {ztyp = ztyp, zterm = zterm, typ = typ} end;
 
-in
-
 fun norm_type tyenv =
   if Vartab.is_empty tyenv then I
   else Same.commit (norm_type_same (ztyp_cache ()) tyenv);
 
 fun norm_term thy envir =
   if Envir.is_empty envir then I
-  else Same.commit (norm_term_same (make_cache thy) envir);
+  else Same.commit (norm_term_same (norm_cache thy) envir);
 
 fun norm_proof thy (envir as Envir.Envir {tyenv, ...}) =
   if Envir.is_empty envir then I
-  else
-    let val cache as {ztyp, ...} = make_cache thy;
-    in Same.commit (map_proof_same (norm_type_same ztyp tyenv) (norm_term_same cache envir)) end;
-
-end;
+  else Same.commit (norm_proof_same (norm_cache thy) envir);