combinators for local theories and lists
authorChristian Urban <urbanc@in.tum.de>
Mon, 11 Jul 2011 14:02:13 +0200
changeset 2962 7a24d827cba9
parent 2961 c2ce4797321a
child 2963 8b22497c25b9
combinators for local theories and lists
Nominal/Nominal2.thy
Nominal/nominal_basics.ML
--- a/Nominal/Nominal2.thy	Mon Jul 11 12:23:44 2011 +0100
+++ b/Nominal/Nominal2.thy	Mon Jul 11 14:02:13 2011 +0200
@@ -215,27 +215,6 @@
 end
 *}
 
-ML {*
-infix 1 ||>>> |>>>
-
-fun (x |>>> f) = 
-  let 
-    val (x', y') = f x 
-  in
-    ([x'], y')
-  end
-
-fun (([], y) ||>>> f) = ([], y)  
-  | ((xs, y) ||>>> f) =
-       let
-         val (x', y') = f y
-       in
-         (xs @ [x'], y')
-       end;
-(op ||>>)
-*}
-
-
 
 ML {*
 fun nominal_datatype2 opt_thms_name dts bn_funs bn_eqs bclauses lthy =
--- a/Nominal/nominal_basics.ML	Mon Jul 11 12:23:44 2011 +0100
+++ b/Nominal/nominal_basics.ML	Mon Jul 11 14:02:13 2011 +0200
@@ -4,11 +4,16 @@
   Basic functions for nominal.
 *)
 
+infix 1 ||>>> |>>>
+
 signature NOMINAL_BASIC =
 sig
   val trace: bool Unsynchronized.ref
   val trace_msg: (unit -> string) -> unit
 
+  val |>>> : 'a * ('a -> 'b * 'c) -> 'b list * 'c
+  val ||>>> : ('a list * 'b) * ('b -> 'a * 'b) -> 'a list * 'b
+
   val last2: 'a list -> 'a * 'a
   val split_triples: ('a * 'b * 'c) list -> ('a list * 'b list * 'c list)
   val split_last2: 'a list -> 'a list * 'a * 'a
@@ -54,6 +59,24 @@
 fun trace_msg msg = if ! trace then tracing (msg ()) else ()
 
 
+infix 1 ||>>> |>>>
+
+fun (x |>>> f) = 
+  let 
+    val (x', y') = f x 
+  in
+    ([x'], y')
+  end
+
+fun (([], y) ||>>> f) = ([], y)  
+  | ((xs, y) ||>>> f) =
+       let
+         val (x', y') = f y
+       in
+         (xs @ [x'], y')
+       end
+
+
 (* orders an AList according to keys - every key needs to be there *)
 fun order eq keys list = 
   map (the o AList.lookup eq list) keys