src/Pure/General/pretty.ML
author wenzelm
Wed, 04 Mar 2009 23:05:32 +0100
changeset 30266 970bf4f594c9
parent 29606 fedb8be05f24
child 30620 16b7ecc183e5
permissions -rw-r--r--
ML antiquotation @{lemma}: allow 'and' list, proper simultaneous type-checking;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6118
caa439435666 fixed titles;
wenzelm
parents: 6116
diff changeset
     1
(*  Title:      Pure/General/pretty.ML
8806
wenzelm
parents: 8456
diff changeset
     2
    Author:     Lawrence C Paulson, Cambridge University Computer Laboratory
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
     3
    Author:     Markus Wenzel, TU Munich
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
     4
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
     5
Generic pretty printing module.
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
     6
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
     7
Loosely based on
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
     8
  D. C. Oppen, "Pretty Printing",
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
     9
  ACM Transactions on Programming Languages and Systems (1980), 465-483.
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    10
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    11
The object to be printed is given as a tree with indentation and line
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    12
breaking information.  A "break" inserts a newline if the text until
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    13
the next break is too long to fit on the current line.  After the newline,
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    14
text is indented to the level of the enclosing block.  Normally, if a block
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    15
is broken then all enclosing blocks will also be broken.  Only "inconsistent
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    16
breaks" are provided.
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    17
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    18
The stored length of a block is used in breakdist (to treat each inner block as
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    19
a unit for breaking).
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    20
*)
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    21
23660
18765718cf62 type output = string indicates raw system output;
wenzelm
parents: 23659
diff changeset
    22
type pprint_args = (output -> unit) * (int -> unit) * (int -> unit) *
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    23
  (unit -> unit) * (unit -> unit);
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    24
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    25
signature PRETTY =
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    26
sig
23660
18765718cf62 type output = string indicates raw system output;
wenzelm
parents: 23659
diff changeset
    27
  val default_indent: string -> int -> output
23698
af84f2f13d4d moved print_mode setup for markup to markup.ML;
wenzelm
parents: 23660
diff changeset
    28
  val add_mode: string -> (string -> int -> output) -> unit
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    29
  type T
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    30
  val str: string -> T
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    31
  val brk: int -> T
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    32
  val fbrk: T
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    33
  val breaks: T list -> T list
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    34
  val fbreaks: T list -> T list
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    35
  val blk: int * T list -> T
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    36
  val block: T list -> T
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    37
  val strs: string list -> T
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    38
  val markup: Markup.T -> T list -> T
26703
c07b1a90600c removed obsolete raw_str;
wenzelm
parents: 24612
diff changeset
    39
  val mark: Markup.T -> T -> T
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    40
  val keyword: string -> T
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    41
  val command: string -> T
23638
09120c2dd71f added markup_chunks;
wenzelm
parents: 23628
diff changeset
    42
  val markup_chunks: Markup.T -> T list -> T
18802
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
    43
  val chunks: T list -> T
19266
2e8ad3f2cd66 added command, keyword;
wenzelm
parents: 18802
diff changeset
    44
  val chunks2: T list -> T
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    45
  val block_enclose: T * T -> T list -> T
18802
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
    46
  val quote: T -> T
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
    47
  val backquote: T -> T
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
    48
  val separate: string -> T list -> T list
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
    49
  val commas: T list -> T list
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    50
  val enclose: string -> string -> T list -> T
18802
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
    51
  val enum: string -> string -> string -> T list -> T
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    52
  val list: string -> string -> T list -> T
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    53
  val str_list: string -> string -> string list -> T
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    54
  val big_list: string -> T list -> T
9730
11d137b25555 added indent;
wenzelm
parents: 9121
diff changeset
    55
  val indent: int -> T -> T
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    56
  val unbreakable: T -> T
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    57
  val setmargin: int -> unit
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    58
  val setmp_margin: int -> ('a -> 'b) -> 'a -> 'b
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    59
  val setdepth: int -> unit
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    60
  val pprint: T -> pprint_args -> unit
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    61
  val symbolicN: string
16714
d9e3ef66b38c added output_buffer;
wenzelm
parents: 15570
diff changeset
    62
  val output_buffer: T -> Buffer.T
23660
18765718cf62 type output = string indicates raw system output;
wenzelm
parents: 23659
diff changeset
    63
  val output: T -> output
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    64
  val string_of: T -> string
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    65
  val str_of: T -> string
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    66
  val writeln: T -> unit
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    67
  type pp
14972
wenzelm
parents: 14832
diff changeset
    68
  val pp: (term -> T) * (typ -> T) * (sort -> T) * (class list -> T) * (arity -> T) -> pp
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    69
  val term: pp -> term -> T
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    70
  val typ: pp -> typ -> T
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    71
  val sort: pp -> sort -> T
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    72
  val classrel: pp -> class list -> T
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    73
  val arity: pp -> arity -> T
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    74
  val string_of_term: pp -> term -> string
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    75
  val string_of_typ: pp -> typ -> string
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    76
  val string_of_sort: pp -> sort -> string
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    77
  val string_of_classrel: pp -> class list -> string
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    78
  val string_of_arity: pp -> arity -> string
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
    79
end;
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    80
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    81
structure Pretty: PRETTY =
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    82
struct
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
    83
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    84
(** print mode operations **)
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    85
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    86
fun default_indent (_: string) = Symbol.spaces;
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    87
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    88
local
23698
af84f2f13d4d moved print_mode setup for markup to markup.ML;
wenzelm
parents: 23660
diff changeset
    89
  val default = {indent = default_indent};
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    90
  val modes = ref (Symtab.make [("", default)]);
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    91
in
23922
707639e9497d marked some CRITICAL sections (for multithreading);
wenzelm
parents: 23787
diff changeset
    92
  fun add_mode name indent = CRITICAL (fn () =>
707639e9497d marked some CRITICAL sections (for multithreading);
wenzelm
parents: 23787
diff changeset
    93
    change modes (Symtab.update_new (name, {indent = indent})));
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    94
  fun get_mode () =
24612
d1b315bdb8d7 avoid direct access to print_mode;
wenzelm
parents: 23922
diff changeset
    95
    the_default default (Library.get_first (Symtab.lookup (! modes)) (print_mode_value ()));
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    96
end;
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    97
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
    98
fun mode_indent x y = #indent (get_mode ()) x y;
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
    99
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   100
val output_spaces = Output.output o Symbol.spaces;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   101
val add_indent = Buffer.add o output_spaces;
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   102
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   103
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   104
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   105
(** printing items: compound phrases, strings, and breaks **)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   106
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   107
datatype T =
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   108
  Block of Markup.T * T list * int * int |  (*markup, body, indentation, length*)
23660
18765718cf62 type output = string indicates raw system output;
wenzelm
parents: 23659
diff changeset
   109
  String of output * int |                  (*text, length*)
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   110
  Break of bool * int;                      (*mandatory flag, width if not taken*)
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   111
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   112
fun length (Block (_, _, _, len)) = len
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   113
  | length (String (_, len)) = len
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   114
  | length (Break (_, wd)) = wd;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   115
9730
11d137b25555 added indent;
wenzelm
parents: 9121
diff changeset
   116
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   117
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   118
(** derived operations to create formatting expressions **)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   119
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   120
val str = String o Output.output_width;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   121
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   122
fun brk wd = Break (false, wd);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   123
val fbrk = Break (true, 2);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   124
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   125
fun breaks prts = Library.separate (brk 1) prts;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   126
fun fbreaks prts = Library.separate fbrk prts;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   127
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   128
fun markup_block m (indent, es) =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   129
  let
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   130
    fun sum [] k = k
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   131
      | sum (e :: es) k = sum es (length e + k);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   132
  in Block (m, es, indent, sum es 0) end;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   133
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   134
val blk = markup_block Markup.none;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   135
fun block prts = blk (2, prts);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   136
val strs = block o breaks o map str;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   137
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   138
fun markup m prts = markup_block m (0, prts);
26703
c07b1a90600c removed obsolete raw_str;
wenzelm
parents: 24612
diff changeset
   139
fun mark m prt = markup m [prt];
c07b1a90600c removed obsolete raw_str;
wenzelm
parents: 24612
diff changeset
   140
fun keyword name = mark (Markup.keyword name) (str name);
c07b1a90600c removed obsolete raw_str;
wenzelm
parents: 24612
diff changeset
   141
fun command name = mark (Markup.command name) (str name);
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   142
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   143
fun markup_chunks m prts = markup m (fbreaks prts);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   144
val chunks = markup_chunks Markup.none;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   145
fun chunks2 prts = blk (0, flat (Library.separate [fbrk, fbrk] (map single prts)));
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   146
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   147
fun block_enclose (p1, p2) ps = chunks [(block  o fbreaks) (p1 :: ps), p2];
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   148
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   149
fun quote prt = blk (1, [str "\"", prt, str "\""]);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   150
fun backquote prt = blk (1, [str "`", prt, str "`"]);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   151
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   152
fun separate sep prts =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   153
  flat (Library.separate [str sep, brk 1] (map single prts));
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   154
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   155
val commas = separate ",";
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   156
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   157
fun enclose lpar rpar prts =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   158
  block (str lpar :: (prts @ [str rpar]));
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   159
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   160
fun enum sep lpar rpar prts = enclose lpar rpar (separate sep prts);
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   161
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   162
val list = enum ",";
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   163
fun str_list lpar rpar strs = list lpar rpar (map str strs);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   164
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   165
fun big_list name prts = block (fbreaks (str name :: prts));
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   166
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   167
fun indent 0 prt = prt
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   168
  | indent n prt = blk (0, [str (Symbol.spaces n), prt]);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   169
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   170
fun unbreakable (Break (_, wd)) = String (output_spaces wd, wd)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   171
  | unbreakable (Block (m, es, indent, wd)) = Block (m, map unbreakable es, indent, wd)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   172
  | unbreakable (e as String _) = e;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   173
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   174
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   175
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   176
(** formatting **)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   177
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   178
(* margin *)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   179
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   180
fun make_margin_info m =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   181
 {margin = m,                   (*right margin, or page width*)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   182
  breakgain = m div 20,         (*minimum added space required of a break*)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   183
  emergencypos = m div 2};      (*position too far to right*)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   184
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   185
val margin_info = ref (make_margin_info 76);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   186
fun setmargin m = margin_info := make_margin_info m;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   187
fun setmp_margin m f = setmp margin_info (make_margin_info m) f;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   188
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   189
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   190
(* depth limitation *)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   191
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   192
val depth = ref 0;   (*maximum depth; 0 means no limit*)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   193
fun setdepth dp = (depth := dp);
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   194
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   195
local
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   196
  fun pruning dp (Block (m, bes, indent, wd)) =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   197
        if dp > 0
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   198
        then markup_block m (indent, map (pruning (dp - 1)) bes)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   199
        else str "..."
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   200
    | pruning dp e = e
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   201
in
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   202
  fun prune e = if ! depth > 0 then pruning (! depth) e else e;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   203
end;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   204
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   205
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   206
(* formatted output *)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   207
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   208
local
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   209
17756
d4a35f82fbb4 minor tweaks for Poplog/ML;
wenzelm
parents: 17542
diff changeset
   210
type text = {tx: Buffer.T, ind: Buffer.T, pos: int, nl: int};
d4a35f82fbb4 minor tweaks for Poplog/ML;
wenzelm
parents: 17542
diff changeset
   211
d4a35f82fbb4 minor tweaks for Poplog/ML;
wenzelm
parents: 17542
diff changeset
   212
val empty: text =
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   213
 {tx = Buffer.empty,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   214
  ind = Buffer.empty,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   215
  pos = 0,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   216
  nl = 0};
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   217
17756
d4a35f82fbb4 minor tweaks for Poplog/ML;
wenzelm
parents: 17542
diff changeset
   218
fun newline {tx, ind, pos, nl} : text =
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   219
 {tx = Buffer.add (Output.output "\n") tx,
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   220
  ind = Buffer.empty,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   221
  pos = 0,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   222
  nl = nl + 1};
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   223
23628
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   224
fun control s {tx, ind, pos: int, nl} : text =
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   225
 {tx = Buffer.add s tx,
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   226
  ind = ind,
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   227
  pos = pos,
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   228
  nl = nl};
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   229
17756
d4a35f82fbb4 minor tweaks for Poplog/ML;
wenzelm
parents: 17542
diff changeset
   230
fun string (s, len) {tx, ind, pos: int, nl} : text =
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   231
 {tx = Buffer.add s tx,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   232
  ind = Buffer.add s ind,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   233
  pos = pos + len,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   234
  nl = nl};
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   235
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   236
fun blanks wd = string (output_spaces wd, wd);
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   237
17756
d4a35f82fbb4 minor tweaks for Poplog/ML;
wenzelm
parents: 17542
diff changeset
   238
fun indentation (buf, len) {tx, ind, pos, nl} : text =
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   239
  let val s = Buffer.content buf in
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   240
   {tx = Buffer.add (mode_indent s len) tx,
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   241
    ind = Buffer.add s ind,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   242
    pos = pos + len,
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   243
    nl = nl}
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   244
  end;
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   245
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   246
(*Add the lengths of the expressions until the next Break; if no Break then
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   247
  include "after", to account for text following this block.*)
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   248
fun breakdist (Block (_, _, _, len) :: es, after) = len + breakdist (es, after)
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   249
  | breakdist (String (s, len) :: es, after) = len + breakdist (es, after)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   250
  | breakdist (Break _ :: es, after) = 0
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   251
  | breakdist ([], after) = after;
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   252
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   253
(*Search for the next break (at this or higher levels) and force it to occur.*)
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   254
fun forcenext [] = []
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   255
  | forcenext (Break (_, wd) :: es) = Break (true, 0) :: es
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   256
  | forcenext (e :: es) = e :: forcenext es;
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   257
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   258
(*es is list of expressions to print;
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   259
  blockin is the indentation of the current block;
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   260
  after is the width of the following context until next break.*)
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   261
fun format ([], _, _) text = text
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   262
  | format (e :: es, block as (blockind, blockin), after) (text as {ind, pos, nl, ...}) =
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   263
      (case e of
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   264
        Block (markup, bes, indent, wd) =>
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   265
          let
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   266
            val {emergencypos, ...} = ! margin_info;
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   267
            val pos' = pos + indent;
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   268
            val pos'' = pos' mod emergencypos;
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   269
            val block' =
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   270
              if pos' < emergencypos then (ind |> add_indent indent, pos')
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   271
              else (add_indent pos'' Buffer.empty, pos'');
23698
af84f2f13d4d moved print_mode setup for markup to markup.ML;
wenzelm
parents: 23660
diff changeset
   272
            val (bg, en) = Markup.output markup;
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   273
            val btext: text = text
23628
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   274
              |> control bg
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   275
              |> format (bes, block', breakdist (es, after))
23628
41cdbfb9f77b markup: emit as control information -- no indent text;
wenzelm
parents: 23617
diff changeset
   276
              |> control en;
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   277
            (*if this block was broken then force the next break*)
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   278
            val es' = if nl < #nl btext then forcenext es else es;
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   279
          in format (es', block, after) btext end
10952
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   280
      | String str => format (es, block, after) (string str text)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   281
      | Break (force, wd) =>
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   282
          let val {margin, breakgain, ...} = ! margin_info in
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   283
            (*no break if text to next break fits on this line
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   284
              or if breaking would add only breakgain to space*)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   285
            format (es, block, after)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   286
              (if not force andalso
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   287
                  pos + wd <= Int.max (margin - breakdist (es, after), blockin + breakgain)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   288
                then text |> blanks wd  (*just insert wd blanks*)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   289
                else text |> newline |> indentation block)
b520e4f1313b support general indentation (e.g. for non-tt latex output);
wenzelm
parents: 9730
diff changeset
   290
          end);
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   291
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   292
in
19266
2e8ad3f2cd66 added command, keyword;
wenzelm
parents: 18802
diff changeset
   293
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   294
fun formatted e = #tx (format ([prune e], (Buffer.empty, 0), 0) empty);
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   295
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   296
end;
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   297
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   298
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   299
(* special output *)
18802
f449d516f36b renamed gen_list to enum;
wenzelm
parents: 18603
diff changeset
   300
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   301
(*symbolic markup -- no formatting*)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   302
fun symbolic prt =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   303
  let
23787
4868d3913961 Buffer.markup;
wenzelm
parents: 23698
diff changeset
   304
    fun out (Block (m, [], _, _)) = Buffer.markup m I
23659
4b702ac388d6 symbolic output: avoid empty blocks, 1 space for fbreak;
wenzelm
parents: 23645
diff changeset
   305
      | out (Block (m, prts, indent, _)) =
23787
4868d3913961 Buffer.markup;
wenzelm
parents: 23698
diff changeset
   306
          Buffer.markup m (Buffer.markup (Markup.block indent) (fold out prts))
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   307
      | out (String (s, _)) = Buffer.add s
23787
4868d3913961 Buffer.markup;
wenzelm
parents: 23698
diff changeset
   308
      | out (Break (false, wd)) = Buffer.markup (Markup.break wd) (Buffer.add (output_spaces wd))
4868d3913961 Buffer.markup;
wenzelm
parents: 23698
diff changeset
   309
      | out (Break (true, _)) = Buffer.markup Markup.fbreak (Buffer.add (output_spaces 1));
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   310
  in out prt Buffer.empty end;
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   311
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   312
(*unformatted output*)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   313
fun unformatted prt =
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   314
  let
23787
4868d3913961 Buffer.markup;
wenzelm
parents: 23698
diff changeset
   315
    fun fmt (Block (m, prts, _, _)) = Buffer.markup m (fold fmt prts)
23617
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   316
      | fmt (String (s, _)) = Buffer.add s
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   317
      | fmt (Break (false, wd)) = Buffer.add (output_spaces wd)
840904fc1eb1 added print_mode setup: indent and markup;
wenzelm
parents: 22019
diff changeset
   318
      | fmt (Break (true, _)) = Buffer.add (output_spaces 1);
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   319
  in fmt (prune prt) Buffer.empty end;
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   320
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   321
(*ML toplevel pretty printing*)
27351
6b120fb45278 pprint: back to proper output of markup, with workaround for Poly/ML crash;
wenzelm
parents: 27350
diff changeset
   322
fun pprint prt (put_str0, begin_blk, put_brk, put_fbrk, end_blk) =
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   323
  let
27351
6b120fb45278 pprint: back to proper output of markup, with workaround for Poly/ML crash;
wenzelm
parents: 27350
diff changeset
   324
    fun put_str "" = ()
6b120fb45278 pprint: back to proper output of markup, with workaround for Poly/ML crash;
wenzelm
parents: 27350
diff changeset
   325
      | put_str s = put_str0 s;
6b120fb45278 pprint: back to proper output of markup, with workaround for Poly/ML crash;
wenzelm
parents: 27350
diff changeset
   326
    fun pp (Block (m, prts, ind, _)) =
6b120fb45278 pprint: back to proper output of markup, with workaround for Poly/ML crash;
wenzelm
parents: 27350
diff changeset
   327
          let val (bg, en) = Markup.output m
6b120fb45278 pprint: back to proper output of markup, with workaround for Poly/ML crash;
wenzelm
parents: 27350
diff changeset
   328
          in put_str bg; begin_blk ind; pp_lst prts; end_blk (); put_str en end
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   329
      | pp (String (s, _)) = put_str s
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   330
      | pp (Break (false, wd)) = put_brk wd
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   331
      | pp (Break (true, _)) = put_fbrk ()
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   332
    and pp_lst [] = ()
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   333
      | pp_lst (prt :: prts) = (pp prt; pp_lst prts);
23645
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   334
  in pp (prune prt) end;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   335
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   336
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   337
(* output interfaces *)
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   338
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   339
val symbolicN = "pretty_symbolic";
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   340
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   341
fun output_buffer prt =
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   342
  if print_mode_active symbolicN then symbolic prt
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   343
  else formatted prt;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   344
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   345
val output = Buffer.content o output_buffer;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   346
val string_of = Output.escape o output;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   347
val str_of = Output.escape o Buffer.content o unformatted;
d220d12bd45e export mode_markup;
wenzelm
parents: 23638
diff changeset
   348
val writeln = Output.writeln o string_of;
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   349
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   350
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   351
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   352
(** abstract pretty printing context **)
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   353
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   354
datatype pp =
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   355
  PP of (term -> T) * (typ -> T) * (sort -> T) * (class list -> T) * (arity -> T);
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   356
14972
wenzelm
parents: 14832
diff changeset
   357
val pp = PP;
14832
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   358
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   359
fun pp_fun f (PP x) = f x;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   360
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   361
val term     = pp_fun #1;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   362
val typ      = pp_fun #2;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   363
val sort     = pp_fun #3;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   364
val classrel = pp_fun #4;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   365
val arity    = pp_fun #5;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   366
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   367
val string_of_term     = string_of oo term;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   368
val string_of_typ      = string_of oo typ;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   369
val string_of_sort     = string_of oo sort;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   370
val string_of_classrel = string_of oo classrel;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   371
val string_of_arity    = string_of oo arity;
6589a58f57cb pp: abstract pretty printing context; string_of/str_of: mark result as raw output; added Pretty.unbreakable;
wenzelm
parents: 12421
diff changeset
   372
6116
8ba2f25610f7 files scan.ML, source.ML, symbol.ML, pretty.ML moved to Pure/General;
wenzelm
parents:
diff changeset
   373
end;