generate "id" rather than (%v. v)
authorblanchet
Tue, 11 Sep 2012 09:40:05 +0200
changeset 49268 9e9dd498fb23
parent 49267 c96a07255e10
child 49269 7157af98ca55
generate "id" rather than (%v. v)
src/HOL/Codatatype/Tools/bnf_fp_sugar.ML
--- a/src/HOL/Codatatype/Tools/bnf_fp_sugar.ML	Tue Sep 11 09:40:05 2012 +0200
+++ b/src/HOL/Codatatype/Tools/bnf_fp_sugar.ML	Tue Sep 11 09:40:05 2012 +0200
@@ -58,9 +58,10 @@
 fun tick v f = Term.lambda v (HOLogic.mk_prod (v, f $ v));
 
 fun tack z_name (c, v) f =
-  let val z = Free (z_name, mk_sumT (fastype_of v, fastype_of c)) in
-    Term.lambda z (mk_sum_case (Term.lambda v v, Term.lambda c (f $ c)) $ z)
-  end;
+  let
+    val T = fastype_of v;
+    val z = Free (z_name, mk_sumT (T, fastype_of c))
+  in Term.lambda z (mk_sum_case (mk_id T, Term.lambda c (f $ c)) $ z) end;
 
 fun cannot_merge_types () = error "Mutually recursive types must have the same type parameters";