src/Pure/Syntax/token_trans.ML
author wenzelm
Fri, 28 Feb 1997 16:42:06 +0100
changeset 2697 60999ba189b7
child 2707 3a1fe1c21b77
permissions -rw-r--r--
Token translations for xterm and LaTeX output.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2697
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Syntax/token_trans.ML
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     3
    Author:     Markus Wenzel, TU Muenchen
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     4
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     5
Token translations for xterm and LaTeX output.
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     6
*)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     7
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     8
signature TOKEN_TRANS =
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
     9
sig
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    10
  val token_translation: (string * string * (string -> string * int)) list
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    11
end;
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    12
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    13
structure TokenTrans: TOKEN_TRANS =
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    14
struct
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    15
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    16
(** misc utils **)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    17
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    18
fun trans_mode m trs = map (fn (s, f) => (m, s, f)) trs;
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    19
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    20
val tok_classes = ["class", "tfree", "tvar", "free", "bound", "var"];
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    21
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    22
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    23
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    24
(** xterm output **)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    25
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    26
(* styles *)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    27
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    28
val normal = "\^[[0m";
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    29
val bold = "\^[[1m";
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    30
val underline = "\^[[4m";
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    31
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    32
fun style s x = (s ^ x ^ normal, size x);
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    33
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    34
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    35
val xterm_trans =
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    36
 trans_mode "xterm"
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    37
  [("bound", style underline),
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    38
   ("free", style bold),
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    39
   ("var", style bold),
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    40
   ("tfree", style bold),
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    41
   ("tvar", style bold)];
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    42
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    43
(* FIXME xterm-color *)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    44
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    45
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    46
(** LaTeX output **)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    47
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    48
(* FIXME 'a -> \alpha etc. *)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    49
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    50
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    51
(** token translations **)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    52
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    53
val token_translation =
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    54
  map (fn s => ("", s, fn x => (x, size x))) tok_classes @
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    55
  (* FIXME tmp test *)
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    56
  map (fn s => ("test", s, fn x => (s ^ "[" ^ x ^ "]", size x + size s + 2))) tok_classes @
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    57
  xterm_trans;
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    58
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    59
60999ba189b7 Token translations for xterm and LaTeX output.
wenzelm
parents:
diff changeset
    60
end;