tuned
authorhaftmann
Mon, 26 Mar 2007 14:53:03 +0200
changeset 22520 ebe95b0242b3
parent 22519 eb70ed79dac7
child 22521 8c000a2ea2f2
tuned
src/HOL/Library/MLString.thy
--- a/src/HOL/Library/MLString.thy	Mon Mar 26 14:53:02 2007 +0200
+++ b/src/HOL/Library/MLString.thy	Mon Mar 26 14:53:03 2007 +0200
@@ -28,10 +28,9 @@
 
 datatype ml_string = STR string
 
-consts
+fun
   explode :: "ml_string \<Rightarrow> string"
-
-primrec
+where
   "explode (STR s) = s"
 
 
@@ -41,14 +40,7 @@
 structure MLString =
 struct
 
-local
-  val thy = the_context ();
-  val const_STR = Sign.intern_const thy "STR";
-in
-  val typ_ml_string = Type (Sign.intern_type thy "ml_string", []);
-  fun term_ml_string s = Const (const_STR, HOLogic.stringT --> typ_ml_string)
-    $ HOLogic.mk_string s
-end;
+fun mk s = @{term STR} $ HOLogic.mk_string s;
 
 end;
 *}
@@ -65,7 +57,7 @@
 
 setup {*
   CodegenSerializer.add_pretty_ml_string "SML"
-    "List.list.Nil" "List.list.Cons" "MLString.ml_string.STR"
+    @{const_name Nil} @{const_name Cons} @{const_name STR}
     ML_Syntax.print_char ML_Syntax.print_string "String.implode"
 *}