syntax fix
authorhaftmann
Fri, 10 Aug 2007 17:10:05 +0200
changeset 24224 a5c95bbeb31d
parent 24223 fa9421d52c74
child 24225 348e982c694b
syntax fix
src/HOL/Library/State_Monad.thy
--- a/src/HOL/Library/State_Monad.thy	Fri Aug 10 17:10:04 2007 +0200
+++ b/src/HOL/Library/State_Monad.thy	Fri Aug 10 17:10:05 2007 +0200
@@ -226,16 +226,16 @@
 
 print_translation {*
 let
-  fun unfold_monad (Const (@{const_syntax mbind}, _) $ f $ g) =
+  fun unfold_monad (Const (@{const_syntax mbind}, _) $ f $ Abs (abs as (_, ty, _))) =
         let
-          val ([(v, ty)], g') = Term.strip_abs_eta 1 g;
-        in Const ("_mbind", dummyT) $ Free (v, ty) $ f $ unfold_monad g' end
+          val (v', g') = Syntax.variant_abs abs;
+        in Const ("_mbind", dummyT) $ Free (v', ty) $ f $ unfold_monad g' end
     | unfold_monad (Const (@{const_syntax fcomp}, _) $ f $ g) =
         Const ("_fcomp", dummyT) $ f $ unfold_monad g
-    | unfold_monad (Const (@{const_syntax Let}, _) $ f $ g) =
+    | unfold_monad (Const (@{const_syntax Let}, _) $ f $ Abs (abs as (_, ty, _))) =
         let
-          val ([(v, ty)], g') = Term.strip_abs_eta 1 g;
-        in Const ("_let", dummyT) $ Free (v, ty) $ f $ unfold_monad g' end
+          val (v', g') = Syntax.variant_abs abs;
+        in Const ("_mbind", dummyT) $ Free (v', ty) $ f $ unfold_monad g' end
     | unfold_monad (Const (@{const_syntax Pair}, _) $ f) =
         Const ("return", dummyT) $ f
     | unfold_monad f = f;