make code more robust w.r.t. applied/unapplied map (primrec vs. primcorec)
authorblanchet
Mon, 04 Nov 2013 10:52:41 +0100
changeset 54234 b5310a1b807c
parent 54233 6d64669184ae
child 54235 3aed2ae6eb91
make code more robust w.r.t. applied/unapplied map (primrec vs. primcorec)
src/HOL/BNF/Tools/bnf_fp_n2m_sugar.ML
--- a/src/HOL/BNF/Tools/bnf_fp_n2m_sugar.ML	Mon Nov 04 10:52:41 2013 +0100
+++ b/src/HOL/BNF/Tools/bnf_fp_n2m_sugar.ML	Mon Nov 04 10:52:41 2013 +0100
@@ -88,17 +88,21 @@
           _ :: _ :: _ => heterogeneous_call call
         | kks => kks);
 
-      fun freeze_fp calls (T as Type (s, Ts)) =
+      fun freeze_fp_map callss s Ts =
+        Type (s, map2 freeze_fp (flatten_type_args_of_bnf (the (bnf_of no_defs_lthy s)) []
+          (transpose callss)) Ts)
+      and freeze_fp calls (T as Type (s, Ts)) =
           (case map_filter (try (snd o dest_map no_defs_lthy s)) calls of
             [] =>
-            (case union (op = o pairself fst)
-                (maps (fn call => map (rpair call) (get_indices_checked call)) calls) [] of
-              [] => freeze_fp_default T
-            | [(kk, _)] => nth Xs kk
-            | (_, call1) :: (_, call2) :: _ => incompatible_calls call1 call2)
-          | callss =>
-            Type (s, map2 freeze_fp (flatten_type_args_of_bnf (the (bnf_of no_defs_lthy s)) []
-              (transpose callss)) Ts))
+            (case map_filter (try (snd o dest_map no_defs_lthy s o fst o dest_comb)) calls of
+              [] =>
+              (case union (op = o pairself fst)
+                  (maps (fn call => map (rpair call) (get_indices_checked call)) calls) [] of
+                [] => freeze_fp_default T
+              | [(kk, _)] => nth Xs kk
+              | (_, call1) :: (_, call2) :: _ => incompatible_calls call1 call2)
+            | callss => freeze_fp_map callss s Ts)
+          | callss => freeze_fp_map callss s Ts)
         | freeze_fp _ T = T;
 
       val ctr_Tsss = map (map binder_types) ctr_Tss;