misc cleanup;
authorwenzelm
Wed, 23 Apr 2008 15:04:14 +0200
changeset 26742 5a86bc79431c
parent 26741 eb15fd4cd1ad
child 26743 f4cf7d36c63a
misc cleanup;
doc-src/antiquote_setup.ML
--- a/doc-src/antiquote_setup.ML	Wed Apr 23 12:13:08 2008 +0200
+++ b/doc-src/antiquote_setup.ML	Wed Apr 23 15:04:14 2008 +0200
@@ -2,15 +2,41 @@
     ID:         $Id$
     Author:     Makarius
 
-Auxiliary antiquotations for Isabelle manuals.
+Auxiliary antiquotations for the Isabelle manuals.
 *)
 
-local
+structure AntiquoteSetup: sig end =
+struct
 
 structure O = ThyOutput;
 
+
+(* misc utils *)
+
 val str_of_source = space_implode " " o map Args.string_of o #2 o #1 o Args.dest_src;
 
+fun tweak_line s =
+  if ! O.display then s else Symbol.strip_blanks s;
+
+val pretty_text = Pretty.chunks o map Pretty.str o map tweak_line o Library.split_lines;
+
+fun pretty_term ctxt t = Syntax.pretty_term (Variable.auto_fixes t ctxt) t;
+fun pretty_thm ctxt = pretty_term ctxt o Thm.full_prop_of;
+
+
+(* verbatim text *)
+
+val verbatim = space_implode "\\verb,|," o map (enclose "\\verb|" "|") o space_explode "|";
+
+val _ = O.add_commands
+ [("verbatim", O.args (Scan.lift Args.name) (fn _ => fn _ =>
+      split_lines #> map verbatim #> space_implode "\\isasep\\isanewline%\n"))];
+
+
+(* ML text *)
+
+local
+
 fun ml_val (txt1, "") = "fn _ => (" ^ txt1 ^ ");"
   | ml_val (txt1, txt2) = "fn _ => (" ^ txt1 ^ ": " ^ txt2 ^ ");";
 
@@ -24,15 +50,11 @@
 
 fun ml_functor _ = "val _ = ();";  (*no check!*)
 
-val verbatim = space_implode "\\verb,|," o map (enclose "\\verb|" "|") o space_explode "|";
-
 fun index_ml kind ml src ctxt (txt1, txt2) =
   let
     val txt = if txt2 = "" then txt1 else
-      if kind = "type"
-        then txt1 ^ " = " ^ txt2
-      else if kind = "exception"
-        then txt1 ^ " of " ^ txt2
+      if kind = "type" then txt1 ^ " = " ^ txt2
+      else if kind = "exception" then txt1 ^ " of " ^ txt2
       else txt1 ^ ": " ^ txt2;
     val txt' = if kind = "" then txt else kind ^ " " ^ txt;
     val _ = writeln (ml (txt1, txt2));
@@ -48,27 +70,33 @@
 
 fun output_ml ctxt src =
   if ! O.display then enclose "\\begin{verbatim}\n" "\n\\end{verbatim}"
-    else
+  else
     split_lines
     #> map (space_implode "\\verb,|," o map (enclose "\\verb|" "|") o space_explode "|")
     #> space_implode "\\isasep\\isanewline%\n";
 
-fun output_verbatim _ _ = split_lines #> map verbatim #> space_implode "\\isasep\\isanewline%\n";
+fun ml_args x = O.args (Scan.lift (Args.name -- Scan.optional (Args.colon |-- Args.name) "")) x;
+
+in
 
-fun arguments x = O.args (Scan.lift (Args.name -- Scan.optional (Args.colon |-- Args.name) "")) x;
+val _ = O.add_commands
+ [("index_ML", ml_args (index_ml "" ml_val)),
+  ("index_ML_type", ml_args (index_ml "type" ml_type)),
+  ("index_ML_exn", ml_args (index_ml "exception" ml_exn)),
+  ("index_ML_structure", ml_args (index_ml "structure" ml_structure)),
+  ("index_ML_functor", ml_args (index_ml "functor" ml_functor)),
+  ("ML_functor", O.args (Scan.lift Args.name) output_ml),
+  ("ML_text", O.args (Scan.lift Args.name) output_ml)];
 
-fun pretty_thy_file name = (ThyLoad.check_thy Path.current name; Pretty.str name);
+end;
 
 
 (* theorems with names *)
 
-fun tweak_line s =
-  if ! O.display then s else Symbol.strip_blanks s;
+local
 
-val pretty_text = Pretty.chunks o map Pretty.str o map tweak_line o Library.split_lines;
-
-fun output_named_list pretty src ctxt xs =
-  map (apfst (pretty ctxt)) xs        (*always pretty in order to exhibit errors!*)
+fun output_named_thms src ctxt xs =
+  map (apfst (pretty_thm ctxt)) xs        (*always pretty in order to exhibit errors!*)
   |> (if ! O.quotes then map (apfst Pretty.quote) else I)
   |> (if ! O.display then
     map (fn (p, name) =>
@@ -83,23 +111,19 @@
     #> space_implode "\\par\\smallskip%\n"
     #> enclose "\\isa{" "}");
 
-fun pretty_term ctxt t = Syntax.pretty_term (Variable.auto_fixes t ctxt) t;
-fun pretty_thm ctxt = pretty_term ctxt o Thm.full_prop_of;
-
 in
 
 val _ = O.add_commands
- [("index_ML", arguments (index_ml "" ml_val)),
-  ("index_ML_type", arguments (index_ml "type" ml_type)),
-  ("index_ML_exn", arguments (index_ml "exception" ml_exn)),
-  ("index_ML_structure", arguments (index_ml "structure" ml_structure)),
-  ("index_ML_functor", arguments (index_ml "functor" ml_functor)),
-  ("ML_functor", O.args (Scan.lift Args.name) output_verbatim),
-  ("verbatim", O.args (Scan.lift Args.name) output_verbatim),
-  ("thy_file", O.args (Scan.lift Args.name) (O.output (K pretty_thy_file))),
-  ("named_thms", O.args (Scan.repeat (Attrib.thm --
-       Scan.lift (Args.$$$ "(" |-- Args.name --| Args.$$$ ")")))
-     (output_named_list pretty_thm)),
-  ("ML_text", O.args (Scan.lift Args.name) output_ml)];
+ [("named_thms", O.args (Scan.repeat (Attrib.thm --
+      Scan.lift (Args.$$$ "(" |-- Args.name --| Args.$$$ ")"))) output_named_thms)];
 
 end;
+
+
+(* theory files *)
+
+val _ = O.add_commands
+ [("thy_file", O.args (Scan.lift Args.name) (O.output (fn _ => fn name =>
+      (ThyLoad.check_thy Path.current name; Pretty.str name))))];
+
+end;