| author | wenzelm | 
| Thu, 28 Mar 2013 14:01:56 +0100 | |
| changeset 51567 | a86c5e02ba58 | 
| parent 51556 | 7ada6dfa9ab5 | 
| child 51626 | e09446d3caca | 
| permissions | -rw-r--r-- | 
| 22124 | 1 | (* Title: Pure/Thy/thy_output.ML | 
| 2 | Author: Markus Wenzel, TU Muenchen | |
| 3 | ||
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 4 | Theory document output with antiquotations. | 
| 22124 | 5 | *) | 
| 6 | ||
| 7 | signature THY_OUTPUT = | |
| 8 | sig | |
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 9 | val display_default: bool Unsynchronized.ref | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 10 | val quotes_default: bool Unsynchronized.ref | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 11 | val indent_default: int Unsynchronized.ref | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 12 | val source_default: bool Unsynchronized.ref | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 13 | val break_default: bool Unsynchronized.ref | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 14 | val display: bool Config.T | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 15 | val quotes: bool Config.T | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 16 | val indent: int Config.T | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 17 | val source: bool Config.T | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 18 | val break: bool Config.T | 
| 38766 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 19 | val add_wrapper: ((unit -> string) -> unit -> string) -> Proof.context -> Proof.context | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 20 | val add_option: binding -> (string -> Proof.context -> Proof.context) -> theory -> theory | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 21 | val intern_command: theory -> xstring -> string | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 22 | val defined_command: theory -> string -> bool | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 23 | val intern_option: theory -> xstring -> string | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 24 | val defined_option: theory -> string -> bool | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 25 | val print_antiquotations: Proof.context -> unit | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 26 | val antiquotation: binding -> 'a context_parser -> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 27 |     ({source: Args.src, state: Toplevel.state, context: Proof.context} -> 'a -> string) ->
 | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 28 | theory -> theory | 
| 22124 | 29 | val boolean: string -> bool | 
| 30 | val integer: string -> int | |
| 31 | datatype markup = Markup | MarkupEnv | Verbatim | |
| 32738 | 32 | val modes: string list Unsynchronized.ref | 
| 42508 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 33 | val eval_antiq: Scan.lexicon -> Toplevel.state -> Symbol_Pos.T list * Position.range -> string | 
| 30573 | 34 | val eval_antiquote: Scan.lexicon -> Toplevel.state -> Symbol_Pos.text * Position.T -> string | 
| 48918 
6e5fd4585512
check side-comments of command spans (normally filtered out in Outer_Syntax.toplevel_source);
 wenzelm parents: 
47005diff
changeset | 35 | val check_text: Symbol_Pos.text * Position.T -> Toplevel.state -> unit | 
| 28427 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 36 | val present_thy: Scan.lexicon -> (string -> string list) -> (markup -> string -> bool) -> | 
| 46811 
03a2dc9e0624
clarified command span: include trailing whitespace/comments and thus reduce number of ignored spans with associated transactions and states (factor 2);
 wenzelm parents: 
46261diff
changeset | 37 | (Toplevel.transition * Toplevel.state) list -> Token.T list -> Buffer.T | 
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 38 | val pretty_text: Proof.context -> string -> Pretty.T | 
| 28644 | 39 | val pretty_term: Proof.context -> term -> Pretty.T | 
| 40 | val pretty_thm: Proof.context -> thm -> Pretty.T | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 41 | val str_of_source: Args.src -> string | 
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 42 | val maybe_pretty_source: (Proof.context -> 'a -> Pretty.T) -> Proof.context -> | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 43 | Args.src -> 'a list -> Pretty.T list | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 44 | val output: Proof.context -> Pretty.T list -> string | 
| 49244 
fb669aff821e
formal markup for @{file} (for hyperlinks etc.) -- interpret path wrt. master directory as usual;
 wenzelm parents: 
48992diff
changeset | 45 | val verb_text: string -> string | 
| 22124 | 46 | end; | 
| 47 | ||
| 37216 
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
 wenzelm parents: 
37198diff
changeset | 48 | structure Thy_Output: THY_OUTPUT = | 
| 22124 | 49 | struct | 
| 50 | ||
| 51 | (** global options **) | |
| 52 | ||
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 53 | val display_default = Unsynchronized.ref false; | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 54 | val quotes_default = Unsynchronized.ref false; | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 55 | val indent_default = Unsynchronized.ref 0; | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 56 | val source_default = Unsynchronized.ref false; | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 57 | val break_default = Unsynchronized.ref false; | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 58 | |
| 42616 
92715b528e78
added Attrib.setup_config_XXX conveniences, with implicit setup of the background theory;
 wenzelm parents: 
42508diff
changeset | 59 | val display = Attrib.setup_config_bool (Binding.name "thy_output_display") (fn _ => ! display_default); | 
| 
92715b528e78
added Attrib.setup_config_XXX conveniences, with implicit setup of the background theory;
 wenzelm parents: 
42508diff
changeset | 60 | val quotes = Attrib.setup_config_bool (Binding.name "thy_output_quotes") (fn _ => ! quotes_default); | 
| 
92715b528e78
added Attrib.setup_config_XXX conveniences, with implicit setup of the background theory;
 wenzelm parents: 
42508diff
changeset | 61 | val indent = Attrib.setup_config_int (Binding.name "thy_output_indent") (fn _ => ! indent_default); | 
| 
92715b528e78
added Attrib.setup_config_XXX conveniences, with implicit setup of the background theory;
 wenzelm parents: 
42508diff
changeset | 62 | val source = Attrib.setup_config_bool (Binding.name "thy_output_source") (fn _ => ! source_default); | 
| 
92715b528e78
added Attrib.setup_config_XXX conveniences, with implicit setup of the background theory;
 wenzelm parents: 
42508diff
changeset | 63 | val break = Attrib.setup_config_bool (Binding.name "thy_output_break") (fn _ => ! break_default); | 
| 22124 | 64 | |
| 65 | ||
| 38766 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 66 | structure Wrappers = Proof_Data | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 67 | ( | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 68 | type T = ((unit -> string) -> unit -> string) list; | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 69 | fun init _ = []; | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 70 | ); | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 71 | |
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 72 | fun add_wrapper wrapper = Wrappers.map (cons wrapper); | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 73 | |
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 74 | val wrap = Wrappers.get #> fold (fn wrapper => fn f => wrapper f); | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 75 | |
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 76 | |
| 22124 | 77 | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 78 | (** maintain global antiquotations **) | 
| 22124 | 79 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 80 | structure Antiquotations = Theory_Data | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 81 | ( | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 82 | type T = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 83 | (Args.src -> Toplevel.state -> Proof.context -> string) Name_Space.table * | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 84 | (string -> Proof.context -> Proof.context) Name_Space.table; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 85 | val empty : T = | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
49847diff
changeset | 86 | (Name_Space.empty_table Markup.document_antiquotationN, | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
49847diff
changeset | 87 | Name_Space.empty_table Markup.document_antiquotation_optionN); | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 88 | val extend = I; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 89 | fun merge ((commands1, options1), (commands2, options2)) : T = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 90 | (Name_Space.merge_tables (commands1, commands2), | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 91 | Name_Space.merge_tables (options1, options2)); | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 92 | ); | 
| 22124 | 93 | |
| 47005 
421760a1efe7
maintain generic context naming in structure Name_Space (NB: empty = default_naming, init = local_naming);
 wenzelm parents: 
46958diff
changeset | 94 | fun add_command name cmd thy = thy | 
| 
421760a1efe7
maintain generic context naming in structure Name_Space (NB: empty = default_naming, init = local_naming);
 wenzelm parents: 
46958diff
changeset | 95 | |> Antiquotations.map (apfst (Name_Space.define (Context.Theory thy) true (name, cmd) #> snd)); | 
| 22124 | 96 | |
| 47005 
421760a1efe7
maintain generic context naming in structure Name_Space (NB: empty = default_naming, init = local_naming);
 wenzelm parents: 
46958diff
changeset | 97 | fun add_option name opt thy = thy | 
| 
421760a1efe7
maintain generic context naming in structure Name_Space (NB: empty = default_naming, init = local_naming);
 wenzelm parents: 
46958diff
changeset | 98 | |> Antiquotations.map (apsnd (Name_Space.define (Context.Theory thy) true (name, opt) #> snd)); | 
| 22124 | 99 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 100 | val intern_command = Name_Space.intern o #1 o #1 o Antiquotations.get; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 101 | val defined_command = Symtab.defined o #2 o #1 o Antiquotations.get; | 
| 26893 | 102 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 103 | val intern_option = Name_Space.intern o #1 o #2 o Antiquotations.get; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 104 | val defined_option = Symtab.defined o #2 o #2 o Antiquotations.get; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 105 | |
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 106 | fun command src state ctxt = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 107 | let | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 108 | val thy = Proof_Context.theory_of ctxt; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 109 | val ((xname, _), pos) = Args.dest_src src; | 
| 47005 
421760a1efe7
maintain generic context naming in structure Name_Space (NB: empty = default_naming, init = local_naming);
 wenzelm parents: 
46958diff
changeset | 110 | val (name, f) = Name_Space.check (Context.Proof ctxt) (#1 (Antiquotations.get thy)) (xname, pos); | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 111 | in | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 112 | f src state ctxt handle ERROR msg => | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 113 |       cat_error msg ("The error(s) above occurred in document antiquotation: " ^
 | 
| 48992 | 114 | quote name ^ Position.here pos) | 
| 22124 | 115 | end; | 
| 116 | ||
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 117 | fun option ((xname, pos), s) ctxt = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 118 | let | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 119 | val thy = Proof_Context.theory_of ctxt; | 
| 47005 
421760a1efe7
maintain generic context naming in structure Name_Space (NB: empty = default_naming, init = local_naming);
 wenzelm parents: 
46958diff
changeset | 120 | val (_, opt) = Name_Space.check (Context.Proof ctxt) (#2 (Antiquotations.get thy)) (xname, pos); | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 121 | in opt s ctxt end; | 
| 22124 | 122 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 123 | fun print_antiquotations ctxt = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 124 | let | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 125 | val thy = Proof_Context.theory_of ctxt; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 126 | val (commands, options) = Antiquotations.get thy; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 127 | val command_names = map #1 (Name_Space.extern_table ctxt commands); | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 128 | val option_names = map #1 (Name_Space.extern_table ctxt options); | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 129 | in | 
| 50301 | 130 | [Pretty.big_list "document antiquotations:" (map Pretty.mark_str command_names), | 
| 131 | Pretty.big_list "document antiquotation options:" (map Pretty.mark_str option_names)] | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 132 | |> Pretty.chunks |> Pretty.writeln | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 133 | end; | 
| 22124 | 134 | |
| 38766 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 135 | fun antiquotation name scan out = | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 136 | add_command name | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 137 | (fn src => fn state => fn ctxt => | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 138 | let val (x, ctxt') = Args.context_syntax "document antiquotation" scan src ctxt | 
| 
8891f4520d16
Thy_Output: options based on proper context, although Thy_Output.add_wrapper still allows to maintain old-style wrapper combinators (setmp_CRITICAL etc.);
 wenzelm parents: 
37216diff
changeset | 139 |       in out {source = src, state = state, context = ctxt'} x end);
 | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 140 | |
| 22124 | 141 | |
| 142 | ||
| 143 | (** syntax of antiquotations **) | |
| 144 | ||
| 145 | (* option values *) | |
| 146 | ||
| 147 | fun boolean "" = true | |
| 148 | | boolean "true" = true | |
| 149 | | boolean "false" = false | |
| 150 |   | boolean s = error ("Bad boolean value: " ^ quote s);
 | |
| 151 | ||
| 152 | fun integer s = | |
| 153 | let | |
| 154 | fun int ss = | |
| 155 | (case Library.read_int ss of (i, []) => i | |
| 156 |       | _ => error ("Bad integer value: " ^ quote s));
 | |
| 157 | in (case Symbol.explode s of "-" :: ss => ~ (int ss) | ss => int ss) end; | |
| 158 | ||
| 159 | ||
| 160 | (* outer syntax *) | |
| 161 | ||
| 162 | local | |
| 163 | ||
| 36950 | 164 | val property = | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 165 | Parse.position Parse.xname -- Scan.optional (Parse.$$$ "=" |-- Parse.!!! Parse.xname) ""; | 
| 36950 | 166 | |
| 167 | val properties = | |
| 168 | Scan.optional (Parse.$$$ "[" |-- Parse.!!! (Parse.enum "," property --| Parse.$$$ "]")) []; | |
| 22124 | 169 | |
| 170 | in | |
| 171 | ||
| 36950 | 172 | val antiq = | 
| 40800 
330eb65c9469
Parse.liberal_name for document antiquotations and attributes;
 wenzelm parents: 
39689diff
changeset | 173 | Parse.!!! | 
| 
330eb65c9469
Parse.liberal_name for document antiquotations and attributes;
 wenzelm parents: 
39689diff
changeset | 174 | (Parse.position Parse.liberal_name -- properties -- Args.parse --| Scan.ahead Parse.eof) | 
| 22124 | 175 | >> (fn (((x, pos), y), z) => (y, Args.src ((x, z), pos))); | 
| 176 | ||
| 177 | end; | |
| 178 | ||
| 179 | ||
| 180 | (* eval_antiquote *) | |
| 181 | ||
| 32738 | 182 | val modes = Unsynchronized.ref ([]: string list); | 
| 22124 | 183 | |
| 42508 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 184 | fun eval_antiq lex state (ss, (pos, _)) = | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 185 | let | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 186 | val (opts, src) = Token.read_antiq lex antiq (ss, pos); | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 187 | fun cmd ctxt = wrap ctxt (fn () => command src state ctxt) (); | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 188 | val preview_ctxt = fold option opts (Toplevel.presentation_context_of state); | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 189 | val print_ctxt = Context_Position.set_visible false preview_ctxt; | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 190 | val _ = cmd preview_ctxt; | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 191 | in Print_Mode.with_modes (! modes @ Latex.modes) (fn () => cmd print_ctxt) () end; | 
| 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 192 | |
| 30367 | 193 | fun eval_antiquote lex state (txt, pos) = | 
| 22124 | 194 | let | 
| 30589 | 195 | fun expand (Antiquote.Text ss) = Symbol_Pos.content ss | 
| 42508 
e21362bf1d93
allow nested @{antiq} (nonterminal) and @@{antiq} terminal;
 wenzelm parents: 
42399diff
changeset | 196 | | expand (Antiquote.Antiq antiq) = eval_antiq lex state antiq | 
| 27344 | 197 | | expand (Antiquote.Open _) = "" | 
| 198 | | expand (Antiquote.Close _) = ""; | |
| 30642 | 199 | val ants = Antiquote.read (Symbol_Pos.explode (txt, pos), pos); | 
| 22124 | 200 | in | 
| 30635 
a7d175c48228
replaced Antiquote.is_antiq by Antiquote.is_text;
 wenzelm parents: 
30613diff
changeset | 201 | if Toplevel.is_toplevel state andalso not (forall Antiquote.is_text ants) then | 
| 48992 | 202 |       error ("Unknown context -- cannot expand document antiquotations" ^ Position.here pos)
 | 
| 22124 | 203 | else implode (map expand ants) | 
| 204 | end; | |
| 205 | ||
| 206 | ||
| 48918 
6e5fd4585512
check side-comments of command spans (normally filtered out in Outer_Syntax.toplevel_source);
 wenzelm parents: 
47005diff
changeset | 207 | fun check_text (txt, pos) state = | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
49847diff
changeset | 208 | (Position.report pos Markup.doc_source; | 
| 51556 | 209 | if Toplevel.is_skipped_proof state then () | 
| 210 | else ignore (eval_antiquote (#1 (Keyword.get_lexicons ())) state (txt, pos))); | |
| 48918 
6e5fd4585512
check side-comments of command spans (normally filtered out in Outer_Syntax.toplevel_source);
 wenzelm parents: 
47005diff
changeset | 211 | |
| 
6e5fd4585512
check side-comments of command spans (normally filtered out in Outer_Syntax.toplevel_source);
 wenzelm parents: 
47005diff
changeset | 212 | |
| 22124 | 213 | |
| 214 | (** present theory source **) | |
| 215 | ||
| 216 | (*NB: arranging white space around command spans is a black art.*) | |
| 217 | ||
| 218 | (* presentation tokens *) | |
| 219 | ||
| 220 | datatype token = | |
| 221 | NoToken | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 222 | | BasicToken of Token.T | 
| 22124 | 223 | | MarkupToken of string * (string * Position.T) | 
| 224 | | MarkupEnvToken of string * (string * Position.T) | |
| 225 | | VerbatimToken of string * Position.T; | |
| 226 | ||
| 227 | fun output_token lex state = | |
| 30367 | 228 | let val eval = eval_antiquote lex state in | 
| 22124 | 229 | fn NoToken => "" | 
| 230 | | BasicToken tok => Latex.output_basic tok | |
| 231 | | MarkupToken (cmd, txt) => Latex.output_markup cmd (eval txt) | |
| 232 | | MarkupEnvToken (cmd, txt) => Latex.output_markup_env cmd (eval txt) | |
| 233 | | VerbatimToken txt => Latex.output_verbatim (eval txt) | |
| 234 | end; | |
| 235 | ||
| 236 | fun basic_token pred (BasicToken tok) = pred tok | |
| 237 | | basic_token _ _ = false; | |
| 238 | ||
| 51267 | 239 | val improper_token = basic_token Token.is_improper; | 
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 240 | val comment_token = basic_token Token.is_comment; | 
| 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 241 | val blank_token = basic_token Token.is_blank; | 
| 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 242 | val newline_token = basic_token Token.is_newline; | 
| 22124 | 243 | |
| 244 | ||
| 245 | (* command spans *) | |
| 246 | ||
| 247 | type command = string * Position.T * string list; (*name, position, tags*) | |
| 248 | type source = (token * (string * int)) list; (*token, markup flag, meta-comment depth*) | |
| 249 | ||
| 250 | datatype span = Span of command * (source * source * source * source) * bool; | |
| 251 | ||
| 252 | fun make_span cmd src = | |
| 253 | let | |
| 254 | fun take_newline (tok :: toks) = | |
| 255 | if newline_token (fst tok) then ([tok], toks, true) | |
| 256 | else ([], tok :: toks, false) | |
| 257 | | take_newline [] = ([], [], false); | |
| 258 | val (((src_prefix, src_main), src_suffix1), (src_suffix2, src_appendix, newline)) = | |
| 259 | src | |
| 260 | |> take_prefix (improper_token o fst) | |
| 261 | ||>> take_suffix (improper_token o fst) | |
| 262 | ||>> take_prefix (comment_token o fst) | |
| 263 | ||> take_newline; | |
| 264 | in Span (cmd, (src_prefix, src_main, src_suffix1 @ src_suffix2, src_appendix), newline) end; | |
| 265 | ||
| 266 | ||
| 267 | (* present spans *) | |
| 268 | ||
| 269 | local | |
| 270 | ||
| 271 | fun err_bad_nesting pos = | |
| 272 |   error ("Bad nesting of commands in presentation" ^ pos);
 | |
| 273 | ||
| 274 | fun edge which f (x: string option, y) = | |
| 275 | if x = y then I | |
| 276 | else (case which (x, y) of NONE => I | SOME txt => Buffer.add (f txt)); | |
| 277 | ||
| 278 | val begin_tag = edge #2 Latex.begin_tag; | |
| 279 | val end_tag = edge #1 Latex.end_tag; | |
| 280 | fun open_delim delim e = edge #2 Latex.begin_delim e #> delim #> edge #2 Latex.end_delim e; | |
| 281 | fun close_delim delim e = edge #1 Latex.begin_delim e #> delim #> edge #1 Latex.end_delim e; | |
| 282 | ||
| 283 | in | |
| 284 | ||
| 285 | fun present_span lex default_tags span state state' | |
| 286 | (tag_stack, active_tag, newline, buffer, present_cont) = | |
| 287 | let | |
| 288 | val present = fold (fn (tok, (flag, 0)) => | |
| 289 | Buffer.add (output_token lex state' tok) | |
| 290 | #> Buffer.add flag | |
| 291 | | _ => I); | |
| 292 | ||
| 293 | val Span ((cmd_name, cmd_pos, cmd_tags), srcs, span_newline) = span; | |
| 294 | ||
| 295 | val (tag, tags) = tag_stack; | |
| 46924 | 296 | val tag' = try hd (fold (update (op =)) cmd_tags (the_list tag)); | 
| 22124 | 297 | |
| 298 | val active_tag' = | |
| 299 | if is_some tag' then tag' | |
| 300 | else if cmd_name = "end" andalso not (Toplevel.is_toplevel state') then NONE | |
| 301 | else try hd (default_tags cmd_name); | |
| 302 | val edge = (active_tag, active_tag'); | |
| 303 | ||
| 304 | val newline' = | |
| 305 | if is_none active_tag' then span_newline else newline; | |
| 306 | ||
| 307 | val nesting = Toplevel.level state' - Toplevel.level state; | |
| 308 | val tag_stack' = | |
| 309 | if nesting = 0 andalso not (Toplevel.is_proof state) then tag_stack | |
| 310 | else if nesting >= 0 then (tag', replicate nesting tag @ tags) | |
| 311 | else | |
| 33957 | 312 | (case drop (~ nesting - 1) tags of | 
| 22124 | 313 | tgs :: tgss => (tgs, tgss) | 
| 48992 | 314 | | [] => err_bad_nesting (Position.here cmd_pos)); | 
| 22124 | 315 | |
| 316 | val buffer' = | |
| 317 | buffer | |
| 318 | |> end_tag edge | |
| 319 | |> close_delim (fst present_cont) edge | |
| 320 | |> snd present_cont | |
| 321 | |> open_delim (present (#1 srcs)) edge | |
| 322 | |> begin_tag edge | |
| 323 | |> present (#2 srcs); | |
| 324 | val present_cont' = | |
| 325 | if newline then (present (#3 srcs), present (#4 srcs)) | |
| 326 | else (I, present (#3 srcs) #> present (#4 srcs)); | |
| 327 | in (tag_stack', active_tag', newline', buffer', present_cont') end; | |
| 328 | ||
| 329 | fun present_trailer ((_, tags), active_tag, _, buffer, present_cont) = | |
| 330 | if not (null tags) then err_bad_nesting " at end of theory" | |
| 331 | else | |
| 332 | buffer | |
| 333 | |> end_tag (active_tag, NONE) | |
| 334 | |> close_delim (fst present_cont) (active_tag, NONE) | |
| 335 | |> snd present_cont; | |
| 336 | ||
| 337 | end; | |
| 338 | ||
| 339 | ||
| 28427 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 340 | (* present_thy *) | 
| 22124 | 341 | |
| 342 | datatype markup = Markup | MarkupEnv | Verbatim; | |
| 343 | ||
| 344 | local | |
| 345 | ||
| 346 | val space_proper = | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 347 | Scan.one Token.is_blank -- Scan.many Token.is_comment -- Scan.one Token.is_proper; | 
| 22124 | 348 | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 349 | val is_improper = not o (Token.is_proper orf Token.is_begin_ignore orf Token.is_end_ignore); | 
| 22124 | 350 | val improper = Scan.many is_improper; | 
| 351 | val improper_end = Scan.repeat (Scan.unless space_proper (Scan.one is_improper)); | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 352 | val blank_end = Scan.repeat (Scan.unless space_proper (Scan.one Token.is_blank)); | 
| 22124 | 353 | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 354 | val opt_newline = Scan.option (Scan.one Token.is_newline); | 
| 22124 | 355 | |
| 356 | val ignore = | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 357 | Scan.depend (fn d => opt_newline |-- Scan.one Token.is_begin_ignore | 
| 22124 | 358 | >> pair (d + 1)) || | 
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 359 | Scan.depend (fn d => Scan.one Token.is_end_ignore --| | 
| 43947 
9b00f09f7721
defer evaluation of Scan.message, for improved performance in the frequent situation where failure is handled later (e.g. via ||);
 wenzelm parents: 
43564diff
changeset | 360 | (if d = 0 then Scan.fail_with (K (fn () => "Bad nesting of meta-comments")) else opt_newline) | 
| 22124 | 361 | >> pair (d - 1)); | 
| 362 | ||
| 36950 | 363 | val tag = (improper -- Parse.$$$ "%" -- improper) |-- Parse.!!! (Parse.tag_name --| blank_end); | 
| 22124 | 364 | |
| 365 | val locale = | |
| 36950 | 366 |   Scan.option ((Parse.$$$ "(" -- improper -- Parse.$$$ "in") |--
 | 
| 367 | Parse.!!! (improper |-- Parse.xname --| (improper -- Parse.$$$ ")"))); | |
| 22124 | 368 | |
| 369 | in | |
| 370 | ||
| 46811 
03a2dc9e0624
clarified command span: include trailing whitespace/comments and thus reduce number of ignored spans with associated transactions and states (factor 2);
 wenzelm parents: 
46261diff
changeset | 371 | fun present_thy lex default_tags is_markup command_results toks = | 
| 22124 | 372 | let | 
| 373 | (* tokens *) | |
| 374 | ||
| 375 | val ignored = Scan.state --| ignore | |
| 376 |       >> (fn d => (NONE, (NoToken, ("", d))));
 | |
| 377 | ||
| 378 | fun markup mark mk flag = Scan.peek (fn d => | |
| 36950 | 379 | improper |-- | 
| 46811 
03a2dc9e0624
clarified command span: include trailing whitespace/comments and thus reduce number of ignored spans with associated transactions and states (factor 2);
 wenzelm parents: 
46261diff
changeset | 380 | Parse.position (Scan.one (Token.is_command andf is_markup mark o Token.content_of)) -- | 
| 22124 | 381 | Scan.repeat tag -- | 
| 36950 | 382 | Parse.!!!! ((improper -- locale -- improper) |-- Parse.doc_source --| improper_end) | 
| 22124 | 383 | >> (fn (((tok, pos), tags), txt) => | 
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 384 | let val name = Token.content_of tok | 
| 22124 | 385 | in (SOME (name, pos, tags), (mk (name, txt), (flag, d))) end)); | 
| 386 | ||
| 387 | val command = Scan.peek (fn d => | |
| 46811 
03a2dc9e0624
clarified command span: include trailing whitespace/comments and thus reduce number of ignored spans with associated transactions and states (factor 2);
 wenzelm parents: 
46261diff
changeset | 388 | Parse.position (Scan.one (Token.is_command)) -- | 
| 22124 | 389 | Scan.repeat tag | 
| 390 | >> (fn ((tok, pos), tags) => | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 391 | let val name = Token.content_of tok | 
| 22124 | 392 | in (SOME (name, pos, tags), (BasicToken tok, (Latex.markup_false, d))) end)); | 
| 393 | ||
| 394 | val cmt = Scan.peek (fn d => | |
| 36950 | 395 | Parse.$$$ "--" |-- Parse.!!!! (improper |-- Parse.doc_source) | 
| 22124 | 396 |       >> (fn txt => (NONE, (MarkupToken ("cmt", txt), ("", d)))));
 | 
| 397 | ||
| 398 | val other = Scan.peek (fn d => | |
| 36950 | 399 |        Parse.not_eof >> (fn tok => (NONE, (BasicToken tok, ("", d)))));
 | 
| 22124 | 400 | |
| 401 | val token = | |
| 402 | ignored || | |
| 403 | markup Markup MarkupToken Latex.markup_true || | |
| 404 | markup MarkupEnv MarkupEnvToken Latex.markup_true || | |
| 405 | markup Verbatim (VerbatimToken o #2) "" || | |
| 406 | command || cmt || other; | |
| 407 | ||
| 408 | ||
| 409 | (* spans *) | |
| 410 | ||
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 411 | val is_eof = fn (_, (BasicToken x, _)) => Token.is_eof x | _ => false; | 
| 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 412 |     val stopper = Scan.stopper (K (NONE, (BasicToken Token.eof, ("", 0)))) is_eof;
 | 
| 22124 | 413 | |
| 414 | val cmd = Scan.one (is_some o fst); | |
| 27732 | 415 | val non_cmd = Scan.one (is_none o fst andf not o is_eof) >> #2; | 
| 22124 | 416 | |
| 417 | val comments = Scan.many (comment_token o fst o snd); | |
| 418 | val blank = Scan.one (blank_token o fst o snd); | |
| 419 | val newline = Scan.one (newline_token o fst o snd); | |
| 420 | val before_cmd = | |
| 421 | Scan.option (newline -- comments) -- | |
| 422 | Scan.option (newline -- comments) -- | |
| 423 | Scan.option (blank -- comments) -- cmd; | |
| 424 | ||
| 425 | val span = | |
| 426 | Scan.repeat non_cmd -- cmd -- | |
| 427 | Scan.repeat (Scan.unless before_cmd non_cmd) -- | |
| 428 | Scan.option (newline >> (single o snd)) | |
| 429 | >> (fn (((toks1, (cmd, tok2)), toks3), tok4) => | |
| 430 | make_span (the cmd) (toks1 @ (tok2 :: (toks3 @ the_default [] tok4)))); | |
| 431 | ||
| 432 | val spans = | |
| 46811 
03a2dc9e0624
clarified command span: include trailing whitespace/comments and thus reduce number of ignored spans with associated transactions and states (factor 2);
 wenzelm parents: 
46261diff
changeset | 433 | Source.of_list (filter_out Token.is_semicolon toks) | 
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 434 | |> Source.source' 0 Token.stopper (Scan.error (Scan.bulk token)) NONE | 
| 22124 | 435 | |> Source.source stopper (Scan.error (Scan.bulk span)) NONE | 
| 436 | |> Source.exhaust; | |
| 28427 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 437 | |
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 438 | |
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 439 | (* present commands *) | 
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 440 | |
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 441 | fun present_command tr span st st' = | 
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 442 | Toplevel.setmp_thread_position tr (present_span lex default_tags span st st'); | 
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 443 | |
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 444 | fun present _ [] = I | 
| 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 445 | | present st (((tr, st'), span) :: rest) = present_command tr span st st' #> present st' rest; | 
| 22124 | 446 | in | 
| 28427 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 447 | if length command_results = length spans then | 
| 22124 | 448 | ((NONE, []), NONE, true, Buffer.empty, (I, I)) | 
| 28427 
cc9f7d99fb73
turned process_thy into present_thy, which merely does presentation (wrt. persistent intermediate states);
 wenzelm parents: 
28273diff
changeset | 449 | |> present Toplevel.toplevel (command_results ~~ spans) | 
| 22124 | 450 | |> present_trailer | 
| 451 | else error "Messed-up outer syntax for presentation" | |
| 452 | end; | |
| 453 | ||
| 454 | end; | |
| 455 | ||
| 456 | ||
| 457 | ||
| 458 | (** setup default output **) | |
| 459 | ||
| 460 | (* options *) | |
| 461 | ||
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 462 | val _ = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 463 | Context.>> (Context.map_theory | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 464 | (add_option (Binding.name "show_types") (Config.put show_types o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 465 | add_option (Binding.name "show_sorts") (Config.put show_sorts o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 466 | add_option (Binding.name "show_structs") (Config.put show_structs o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 467 | add_option (Binding.name "show_question_marks") (Config.put show_question_marks o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 468 | add_option (Binding.name "show_abbrevs") (Config.put show_abbrevs o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 469 | add_option (Binding.name "names_long") (Config.put Name_Space.names_long o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 470 | add_option (Binding.name "names_short") (Config.put Name_Space.names_short o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 471 | add_option (Binding.name "names_unique") (Config.put Name_Space.names_unique o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 472 | add_option (Binding.name "eta_contract") (Config.put Syntax_Trans.eta_contract o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 473 | add_option (Binding.name "display") (Config.put display o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 474 | add_option (Binding.name "break") (Config.put break o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 475 | add_option (Binding.name "quotes") (Config.put quotes o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 476 | add_option (Binding.name "mode") (add_wrapper o Print_Mode.with_modes o single) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 477 | add_option (Binding.name "margin") (add_wrapper o setmp_CRITICAL Pretty.margin_default o integer) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 478 | add_option (Binding.name "indent") (Config.put indent o integer) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 479 | add_option (Binding.name "source") (Config.put source o boolean) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 480 | add_option (Binding.name "goals_limit") (Config.put Goal_Display.goals_limit o integer))); | 
| 22124 | 481 | |
| 482 | ||
| 483 | (* basic pretty printing *) | |
| 484 | ||
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 485 | fun tweak_line ctxt s = | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 486 | if Config.get ctxt display then s else Symbol.strip_blanks s; | 
| 22124 | 487 | |
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 488 | fun pretty_text ctxt = | 
| 46195 | 489 | Pretty.chunks o map Pretty.str o map (tweak_line ctxt) o split_lines; | 
| 22124 | 490 | |
| 26710 
f79aa228c582
pretty_term: no revert_skolems here, but auto_fixes (token translations will do the rest);
 wenzelm parents: 
26455diff
changeset | 491 | fun pretty_term ctxt t = Syntax.pretty_term (Variable.auto_fixes t ctxt) t; | 
| 24920 | 492 | |
| 32898 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 493 | fun pretty_thm ctxt = pretty_term ctxt o Thm.full_prop_of; | 
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 494 | |
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 495 | fun pretty_term_style ctxt (style, t) = | 
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 496 | pretty_term ctxt (style t); | 
| 22124 | 497 | |
| 32898 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 498 | fun pretty_thm_style ctxt (style, th) = | 
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 499 | pretty_term ctxt (style (Thm.full_prop_of th)); | 
| 22124 | 500 | |
| 32898 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 501 | fun pretty_term_typ ctxt (style, t) = | 
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 502 | let val t' = style t | 
| 39288 | 503 | in pretty_term ctxt (Type.constraint (Term.fastype_of t') t') end; | 
| 32898 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 504 | |
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 505 | fun pretty_term_typeof ctxt (style, t) = | 
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 506 | Syntax.pretty_typ ctxt (Term.fastype_of (style t)); | 
| 22124 | 507 | |
| 25373 
ccbf65080fdf
@{const}: improved ProofContext.read_const does the job;
 wenzelm parents: 
25241diff
changeset | 508 | fun pretty_const ctxt c = | 
| 
ccbf65080fdf
@{const}: improved ProofContext.read_const does the job;
 wenzelm parents: 
25241diff
changeset | 509 | let | 
| 42360 | 510 | val t = Const (c, Consts.type_scheme (Proof_Context.consts_of ctxt) c) | 
| 25373 
ccbf65080fdf
@{const}: improved ProofContext.read_const does the job;
 wenzelm parents: 
25241diff
changeset | 511 | handle TYPE (msg, _, _) => error msg; | 
| 
ccbf65080fdf
@{const}: improved ProofContext.read_const does the job;
 wenzelm parents: 
25241diff
changeset | 512 | val ([t'], _) = Variable.import_terms true [t] ctxt; | 
| 
ccbf65080fdf
@{const}: improved ProofContext.read_const does the job;
 wenzelm parents: 
25241diff
changeset | 513 | in pretty_term ctxt t' end; | 
| 22124 | 514 | |
| 25407 
2859cf34aaf0
abbrev: bypass full term check via ProofContext.standard_infer_types (prevents forced expansion);
 wenzelm parents: 
25373diff
changeset | 515 | fun pretty_abbrev ctxt s = | 
| 22124 | 516 | let | 
| 42399 | 517 | val t = Syntax.read_term (Proof_Context.set_mode Proof_Context.mode_abbrev ctxt) s; | 
| 24920 | 518 |     fun err () = error ("Abbreviated constant expected: " ^ Syntax.string_of_term ctxt t);
 | 
| 22124 | 519 | val (head, args) = Term.strip_comb t; | 
| 520 | val (c, T) = Term.dest_Const head handle TERM _ => err (); | |
| 42360 | 521 | val (U, u) = Consts.the_abbreviation (Proof_Context.consts_of ctxt) c | 
| 22124 | 522 | handle TYPE _ => err (); | 
| 523 | val t' = Term.betapplys (Envir.expand_atom T (U, u), args); | |
| 32898 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 524 | val eq = Logic.mk_equals (t, t'); | 
| 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 525 | val ctxt' = Variable.auto_fixes eq ctxt; | 
| 42360 | 526 | in Proof_Context.pretty_term_abbrev ctxt' eq end; | 
| 22124 | 527 | |
| 39305 
d4fa19eb0822
'class' and 'type' are now antiquoations by default
 haftmann parents: 
39134diff
changeset | 528 | fun pretty_class ctxt = | 
| 42360 | 529 | Pretty.str o Proof_Context.extern_class ctxt o Proof_Context.read_class ctxt; | 
| 39305 
d4fa19eb0822
'class' and 'type' are now antiquoations by default
 haftmann parents: 
39134diff
changeset | 530 | |
| 39309 
74469faa27ca
type antiquotation: allow arbitrary type abbreviations, but fail with user-space exception on bad input
 haftmann parents: 
39308diff
changeset | 531 | fun pretty_type ctxt s = | 
| 42360 | 532 | let val Type (name, _) = Proof_Context.read_type_name_proper ctxt false s | 
| 533 | in Pretty.str (Proof_Context.extern_type ctxt name) end; | |
| 39305 
d4fa19eb0822
'class' and 'type' are now antiquoations by default
 haftmann parents: 
39134diff
changeset | 534 | |
| 33388 | 535 | fun pretty_prf full ctxt = Proof_Syntax.pretty_proof_of ctxt full; | 
| 22124 | 536 | |
| 48927 
ef462b5558eb
theory def/ref position reports, which enable hyperlinks etc.;
 wenzelm parents: 
48918diff
changeset | 537 | fun pretty_theory ctxt (name, pos) = | 
| 
ef462b5558eb
theory def/ref position reports, which enable hyperlinks etc.;
 wenzelm parents: 
48918diff
changeset | 538 | (case find_first (fn thy => Context.theory_name thy = name) | 
| 
ef462b5558eb
theory def/ref position reports, which enable hyperlinks etc.;
 wenzelm parents: 
48918diff
changeset | 539 | (Theory.nodes_of (Proof_Context.theory_of ctxt)) of | 
| 48992 | 540 |     NONE => error ("No ancestor theory " ^ quote name ^ Position.here pos)
 | 
| 48927 
ef462b5558eb
theory def/ref position reports, which enable hyperlinks etc.;
 wenzelm parents: 
48918diff
changeset | 541 | | SOME thy => (Position.report pos (Theory.get_markup thy); Pretty.str name)); | 
| 22124 | 542 | |
| 543 | ||
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 544 | (* default output *) | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 545 | |
| 36959 
f5417836dbea
renamed structure OuterLex to Token and type token to Token.T, keeping legacy aliases for some time;
 wenzelm parents: 
36950diff
changeset | 546 | val str_of_source = space_implode " " o map Token.unparse o #2 o #1 o Args.dest_src; | 
| 22124 | 547 | |
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 548 | fun maybe_pretty_source pretty ctxt src xs = | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 549 | map (pretty ctxt) xs (*always pretty in order to exhibit errors!*) | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 550 | |> (if Config.get ctxt source then K [pretty_text ctxt (str_of_source src)] else I); | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 551 | |
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 552 | fun output ctxt prts = | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 553 | prts | 
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 554 | |> (if Config.get ctxt quotes then map Pretty.quote else I) | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 555 | |> (if Config.get ctxt display then | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 556 | map (Output.output o Pretty.string_of o Pretty.indent (Config.get ctxt indent)) | 
| 22124 | 557 | #> space_implode "\\isasep\\isanewline%\n" | 
| 558 |     #> enclose "\\begin{isabelle}%\n" "%\n\\end{isabelle}"
 | |
| 559 | else | |
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 560 | map (Output.output o (if Config.get ctxt break then Pretty.string_of else Pretty.str_of)) | 
| 22124 | 561 | #> space_implode "\\isasep\\isanewline%\n" | 
| 562 |     #> enclose "\\isa{" "}");
 | |
| 563 | ||
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 564 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 565 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 566 | (** concrete antiquotations **) | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 567 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 568 | (* basic entities *) | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 569 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 570 | local | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 571 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 572 | fun basic_entities name scan pretty = antiquotation name scan | 
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 573 |   (fn {source, context, ...} => output context o maybe_pretty_source pretty context source);
 | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 574 | |
| 32890 
77df12652210
generalized term styles: transformations may depend on arguments; modernized term_style module; antiquotations thm, prop and term accepting term styles
 haftmann parents: 
32738diff
changeset | 575 | fun basic_entities_style name scan pretty = antiquotation name scan | 
| 
77df12652210
generalized term styles: transformations may depend on arguments; modernized term_style module; antiquotations thm, prop and term accepting term styles
 haftmann parents: 
32738diff
changeset | 576 |   (fn {source, context, ...} => fn (style, xs) =>
 | 
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 577 | output context | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 578 | (maybe_pretty_source (fn ctxt => fn x => pretty ctxt (style, x)) context source xs)); | 
| 32890 
77df12652210
generalized term styles: transformations may depend on arguments; modernized term_style module; antiquotations thm, prop and term accepting term styles
 haftmann parents: 
32738diff
changeset | 579 | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 580 | fun basic_entity name scan = basic_entities name (scan >> single); | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 581 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 582 | in | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 583 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 584 | val _ = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 585 | Context.>> (Context.map_theory | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 586 | (basic_entities_style (Binding.name "thm") (Term_Style.parse -- Attrib.thms) pretty_thm_style #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 587 | basic_entity (Binding.name "prop") (Term_Style.parse -- Args.prop) pretty_term_style #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 588 | basic_entity (Binding.name "term") (Term_Style.parse -- Args.term) pretty_term_style #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 589 | basic_entity (Binding.name "term_type") (Term_Style.parse -- Args.term) pretty_term_typ #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 590 | basic_entity (Binding.name "typeof") (Term_Style.parse -- Args.term) pretty_term_typeof #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 591 | basic_entity (Binding.name "const") (Args.const_proper false) pretty_const #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 592 | basic_entity (Binding.name "abbrev") (Scan.lift Args.name_source) pretty_abbrev #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 593 | basic_entity (Binding.name "typ") Args.typ_abbrev Syntax.pretty_typ #> | 
| 46922 
3717f3878714
source positions for locale and class expressions;
 wenzelm parents: 
46811diff
changeset | 594 | basic_entity (Binding.name "class") (Scan.lift Args.name_source) pretty_class #> | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 595 | basic_entity (Binding.name "type") (Scan.lift Args.name) pretty_type #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 596 | basic_entity (Binding.name "text") (Scan.lift Args.name) pretty_text #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 597 | basic_entities (Binding.name "prf") Attrib.thms (pretty_prf false) #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 598 | basic_entities (Binding.name "full_prf") Attrib.thms (pretty_prf true) #> | 
| 50592 | 599 | basic_entity (Binding.name "theory") (Scan.lift (Parse.position Args.name)) pretty_theory)); | 
| 32898 
e871d897969c
term styles also cover antiquotations term_type and typeof
 haftmann parents: 
32890diff
changeset | 600 | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 601 | end; | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 602 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 603 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 604 | (* goal state *) | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 605 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 606 | local | 
| 22124 | 607 | |
| 30367 | 608 | fun proof_state state = | 
| 49847 | 609 | (case try (Proof.goal o Toplevel.proof_of) state of | 
| 610 |     SOME {goal, ...} => goal
 | |
| 22124 | 611 | | _ => error "No proof state"); | 
| 612 | ||
| 49847 | 613 | fun goal_state name main = antiquotation name (Scan.succeed ()) | 
| 39125 
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
 wenzelm parents: 
38980diff
changeset | 614 |   (fn {state, context = ctxt, ...} => fn () => output ctxt
 | 
| 49847 | 615 |     [Goal_Display.pretty_goal {main = main, limit = true} ctxt (proof_state state)]);
 | 
| 22124 | 616 | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 617 | in | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 618 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 619 | val _ = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 620 | Context.>> (Context.map_theory | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 621 | (goal_state (Binding.name "goals") true #> | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 622 | goal_state (Binding.name "subgoals") false)); | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 623 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 624 | end; | 
| 22124 | 625 | |
| 626 | ||
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 627 | (* embedded lemma *) | 
| 27522 | 628 | |
| 46958 
0ec8f04e753a
define keywords early when processing the theory header, before running the body commands;
 wenzelm parents: 
46957diff
changeset | 629 | val _ = Keyword.define ("by", NONE);  (*overlap with command category*)
 | 
| 46950 
d0181abdbdac
declare command keywords via theory header, including strict checking outside Pure;
 wenzelm parents: 
46947diff
changeset | 630 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 631 | val _ = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 632 | Context.>> (Context.map_theory | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 633 | (antiquotation (Binding.name "lemma") | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 634 | (Args.prop -- Scan.lift (Args.$$$ "by" |-- Method.parse -- Scan.option Method.parse)) | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 635 |     (fn {source, context, ...} => fn (prop, methods) =>
 | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 636 | let | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 637 | val prop_src = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 638 | (case Args.dest_src source of ((a, arg :: _), pos) => Args.src ((a, [arg]), pos)); | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 639 | (* FIXME check proof!? *) | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 640 | val _ = context | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 641 | |> Proof.theorem NONE (K I) [[(prop, [])]] | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 642 | |> Proof.global_terminal_proof methods; | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 643 | in output context (maybe_pretty_source pretty_term context prop_src [prop]) end))); | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 644 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 645 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 646 | (* ML text *) | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 647 | |
| 40801 | 648 | val verb_text = | 
| 649 | split_lines | |
| 650 | #> map (space_implode "\\verb,|," o map (enclose "\\verb|" "|") o space_explode "|") | |
| 651 | #> space_implode "\\isasep\\isanewline%\n"; | |
| 652 | ||
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 653 | local | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 654 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 655 | fun ml_text name ml = antiquotation name (Scan.lift Args.name_source_position) | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 656 |   (fn {context, ...} => fn (txt, pos) =>
 | 
| 37198 
3af985b10550
replaced ML_Lex.read_antiq by more concise ML_Lex.read, which includes full read/report with explicit position information;
 wenzelm parents: 
37146diff
changeset | 657 | (ML_Context.eval_in (SOME context) false pos (ml pos txt); | 
| 30573 | 658 | Symbol_Pos.content (Symbol_Pos.explode (txt, pos)) | 
| 38767 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 659 | |> (if Config.get context quotes then quote else I) | 
| 
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
 wenzelm parents: 
38766diff
changeset | 660 |     |> (if Config.get context display then enclose "\\begin{verbatim}\n" "\n\\end{verbatim}"
 | 
| 40801 | 661 | else verb_text))); | 
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 662 | |
| 37198 
3af985b10550
replaced ML_Lex.read_antiq by more concise ML_Lex.read, which includes full read/report with explicit position information;
 wenzelm parents: 
37146diff
changeset | 663 | fun ml_enclose bg en pos txt = | 
| 
3af985b10550
replaced ML_Lex.read_antiq by more concise ML_Lex.read, which includes full read/report with explicit position information;
 wenzelm parents: 
37146diff
changeset | 664 | ML_Lex.read Position.none bg @ ML_Lex.read pos txt @ ML_Lex.read Position.none en; | 
| 
3af985b10550
replaced ML_Lex.read_antiq by more concise ML_Lex.read, which includes full read/report with explicit position information;
 wenzelm parents: 
37146diff
changeset | 665 | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 666 | in | 
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 667 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 668 | val _ = | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 669 | Context.>> (Context.map_theory | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 670 |    (ml_text (Binding.name "ML") (ml_enclose "fn _ => (" ");") #>
 | 
| 46261 | 671 | ml_text (Binding.name "ML_op") (ml_enclose "fn _ => (op " ");") #> | 
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 672 |     ml_text (Binding.name "ML_type") (ml_enclose "val _ = NONE : (" ") option;") #>
 | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 673 | ml_text (Binding.name "ML_struct") | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 674 | (ml_enclose "functor XXX() = struct structure XX = " " end;") #> | 
| 37198 
3af985b10550
replaced ML_Lex.read_antiq by more concise ML_Lex.read, which includes full read/report with explicit position information;
 wenzelm parents: 
37146diff
changeset | 675 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 676 | ml_text (Binding.name "ML_functor") (* FIXME formal treatment of functor name (!?) *) | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 677 | (fn pos => fn txt => | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 678 |         ML_Lex.read Position.none ("ML_Env.check_functor " ^
 | 
| 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 679 | ML_Syntax.print_string (Symbol_Pos.content (Symbol_Pos.explode (txt, pos))))) #> | 
| 37198 
3af985b10550
replaced ML_Lex.read_antiq by more concise ML_Lex.read, which includes full read/report with explicit position information;
 wenzelm parents: 
37146diff
changeset | 680 | |
| 43564 
9864182c6bad
document antiquotations are managed as theory data, with proper name space and entity markup;
 wenzelm parents: 
42669diff
changeset | 681 | ml_text (Binding.name "ML_text") (K (K [])))); | 
| 22124 | 682 | |
| 683 | end; | |
| 30390 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 684 | |
| 
ad591ee76c78
simplified interface to define document antiquotations, cf. antiquotatation, maybe_pretty_source, output;
 wenzelm parents: 
30381diff
changeset | 685 | end; |