diff -r 9699ad581dc2 -r 69b5ba7518b9 ProgTutorial/First_Steps.thy
--- a/ProgTutorial/First_Steps.thy	Wed Nov 02 13:38:19 2011 +0000
+++ b/ProgTutorial/First_Steps.thy	Thu Nov 03 17:53:36 2011 +0000
@@ -147,7 +147,7 @@
   for example:
 
   @{ML_response_fake [display,gray] 
-  "if 0=1 then true else (error \"foo\")" 
+  "if 0 = 1 then true else (error \"foo\")" 
 "Exception- ERROR \"foo\" raised
 At command \"ML\"."}
 
@@ -645,6 +645,30 @@
   "acc_incs 1 ||>> (fn x => (x, x + 2))"
   "(((((\"\", 1), 2), 3), 4), 6)"}
 
+  An example where this combinator is useful is as follows
+
+  @{ML_response_fake [display, gray]
+  "let
+  val ((names1, names2), _) =
+    @{context}
+    |> Variable.variant_fixes (replicate 4 \"x\")
+    ||>> Variable.variant_fixes (replicate 5 \"x\")
+in
+  (names1, names2)
+end"
+  "([\"x\", \"xa\", \"xb\", \"xc\"], [\"xd\", \"xe\", \"xf\", \"xg\", \"xh\"])"}
+
+  Its purpose is to create nine variants of the string @{ML "\"x\""} so
+  that no variant will clash with another. Suppose for some reason we want
+  to bind four variants to the lists @{ML_text "name1"} and the
+  rest to @{ML_text "name2"}. In order to obtain non-clashing
+  variants we have to thread the context through the function calls
+  (the context records which variants have been previously created).
+  For the first call we can use @{ML "|>"}, but in the
+  second and any further call to @{ML_ind variant_fixes in Variable} we 
+  have to use @{ML "||>>"} in order to account for the result(s) 
+  obtained by previous calls.
+  
   A more realistic example for this combinator is the following code
 *}
 
@@ -672,7 +696,6 @@
 end"
   "one
 one \<equiv> 1"}
-
   Recall that @{ML "|>"} is the reverse function application. Recall also that
   the related reverse function composition is @{ML "#>"}. In fact all the
   combinators @{ML "|->"}, @{ML "|>>"} , @{ML "||>"} and @{ML "||>>"}