| author | wenzelm | 
| Thu, 09 Sep 2021 12:33:14 +0200 | |
| changeset 74266 | 612b7e0d6721 | 
| parent 74263 | be49c660ebbf | 
| child 74671 | df12779c3ce8 | 
| permissions | -rw-r--r-- | 
| 45670 | 1 | (* Title: Pure/PIDE/markup.ML | 
| 23623 | 2 | Author: Makarius | 
| 3 | ||
| 56743 | 4 | Quasi-abstract markup elements. | 
| 23623 | 5 | *) | 
| 6 | ||
| 7 | signature MARKUP = | |
| 8 | sig | |
| 28017 | 9 | type T = string * Properties.T | 
| 38474 
e498dc2eb576
uniform Markup.empty/Markup.Empty in ML and Scala;
 wenzelm parents: 
38429diff
changeset | 10 | val empty: T | 
| 
e498dc2eb576
uniform Markup.empty/Markup.Empty in ML and Scala;
 wenzelm parents: 
38429diff
changeset | 11 | val is_empty: T -> bool | 
| 38229 | 12 | val properties: Properties.T -> T -> T | 
| 68997 | 13 | val nameN: string val name: string -> T -> T | 
| 14 | val xnameN: string val xname: string -> T -> T | |
| 38887 
1261481ef5e5
Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
 wenzelm parents: 
38871diff
changeset | 15 | val kindN: string | 
| 60744 | 16 | val serialN: string | 
| 17 | val serial_properties: int -> Properties.T | |
| 52854 
92932931bd82
more general Output.result: allow to update arbitrary properties;
 wenzelm parents: 
52800diff
changeset | 18 | val instanceN: string | 
| 69889 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 19 | val meta_titleN: string val meta_title: T | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 20 | val meta_creatorN: string val meta_creator: T | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 21 | val meta_contributorN: string val meta_contributor: T | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 22 | val meta_dateN: string val meta_date: T | 
| 69962 
82e945d472d5
documentation of document markers and re-interpreted command tags;
 wenzelm parents: 
69916diff
changeset | 23 | val meta_licenseN: string val meta_license: T | 
| 69889 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 24 | val meta_descriptionN: string val meta_description: T | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 25 | val languageN: string | 
| 55615 
bf4bbe72f740
completion of keywords and symbols based on language context;
 wenzelm parents: 
55613diff
changeset | 26 | val symbolsN: string | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 27 | val delimitedN: string | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 28 | val is_delimited: Properties.T -> bool | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 29 |   val language: {name: string, symbols: bool, antiquotes: bool, delimited: bool} -> T
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 30 |   val language': {name: string, symbols: bool, antiquotes: bool} -> bool -> T
 | 
| 62231 
25f4a9cd8b68
tuned markup, e.g. relevant for Rendering.tooltip;
 wenzelm parents: 
61864diff
changeset | 31 | val language_Isar: bool -> T | 
| 55761 
213b9811f59f
method language markup, e.g. relevant to prevent outer keyword completion;
 wenzelm parents: 
55750diff
changeset | 32 | val language_method: T | 
| 56033 | 33 | val language_attribute: T | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 34 | val language_sort: bool -> T | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 35 | val language_type: bool -> T | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 36 | val language_term: bool -> T | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 37 | val language_prop: bool -> T | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 38 | val language_ML: bool -> T | 
| 56278 
2576d3a40ed6
separate tokenization and language context for SML: no symbols, no antiquotes;
 wenzelm parents: 
56202diff
changeset | 39 | val language_SML: bool -> T | 
| 61600 
1ca11ddfcc70
clarified completion of explicit symbols (see also f6bd97a587b7, e0e4ac981cf1);
 wenzelm parents: 
61598diff
changeset | 40 | val language_document: bool -> T | 
| 69887 | 41 | val language_document_marker: T | 
| 55653 
528de9a20054
more markup -- complete symbols within antiquotation, notably with broken arguments;
 wenzelm parents: 
55615diff
changeset | 42 | val language_antiquotation: T | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 43 | val language_text: bool -> T | 
| 62520 | 44 | val language_verbatim: bool -> T | 
| 67429 | 45 | val language_latex: bool -> T | 
| 55613 | 46 | val language_rail: T | 
| 72841 | 47 | val language_path: bool -> T | 
| 72843 | 48 | val language_url: bool -> T | 
| 62772 | 49 | val language_mixfix: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 50 | val bindingN: string val binding: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 51 | val entityN: string val entity: string -> string -> T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 52 | val defN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 53 | val refN: string | 
| 55694 
a1184dfb8e00
clarified semantic completion: retain kind.full_name as official item name for history;
 wenzelm parents: 
55687diff
changeset | 54 | val completionN: string val completion: T | 
| 55914 
c5b752d549e3
clarified init_assignable: make double-sure that initial values are reset;
 wenzelm parents: 
55837diff
changeset | 55 | val no_completionN: string val no_completion: T | 
| 69557 | 56 | val updateN: string val update: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 57 | val lineN: string | 
| 58978 
e42da880c61e
more position information, e.g. relevant for errors in generated ML source;
 wenzelm parents: 
58855diff
changeset | 58 | val end_lineN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 59 | val offsetN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 60 | val end_offsetN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 61 | val fileN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 62 | val idN: string | 
| 74182 | 63 | val positionN: string val position: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 64 | val position_properties: string list | 
| 72708 | 65 | val position_property: Properties.entry -> bool | 
| 74182 | 66 | val def_name: string -> string | 
| 74263 
be49c660ebbf
more markup, e.g. to locate defining theory node in formal document output;
 wenzelm parents: 
74261diff
changeset | 67 | val def_theoryN: string | 
| 62806 | 68 | val expressionN: string val expression: string -> T | 
| 58545 
30b75b7958d6
citation tooltip/hyperlink based on open buffers with .bib files;
 wenzelm parents: 
58544diff
changeset | 69 | val citationN: string val citation: string -> T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 70 | val pathN: string val path: string -> T | 
| 70016 | 71 | val export_pathN: string val export_path: string -> T | 
| 54702 
3daeba5130f0
added document antiquotation @{url}, which produces formal markup for LaTeX and PIDE;
 wenzelm parents: 
53378diff
changeset | 72 | val urlN: string val url: string -> T | 
| 61660 
78b371644654
added antiquotation @{doc}, e.g. useful for demonstration purposes;
 wenzelm parents: 
61614diff
changeset | 73 | val docN: string val doc: string -> T | 
| 72763 | 74 | val toolN: string val tool: string -> T | 
| 62788 | 75 | val markupN: string | 
| 76 | val consistentN: string | |
| 62789 | 77 | val unbreakableN: string | 
| 62786 | 78 | val block_properties: string list | 
| 62788 | 79 | val indentN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 80 | val widthN: string | 
| 61864 | 81 | val blockN: string val block: bool -> int -> T | 
| 61862 
e2a9e46ac0fb
support pretty break indent, like underlying ML systems;
 wenzelm parents: 
61660diff
changeset | 82 | val breakN: string val break: int -> int -> T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 83 | val fbreakN: string val fbreak: T | 
| 51570 
3633828d80fc
basic support for Pretty.item, which is considered as logical markup and interpreted in Isabelle/Scala, but ignored elsewhere (TTY, latex etc.);
 wenzelm parents: 
51228diff
changeset | 84 | val itemN: string val item: T | 
| 56548 | 85 | val wordsN: string val words: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 86 | val hiddenN: string val hidden: T | 
| 68298 
2c3ce27cf4a8
markup for deleted fragments of token source (NB: quoted tokens transform "\123" implicitly);
 wenzelm parents: 
68101diff
changeset | 87 | val deleteN: string val delete: T | 
| 71912 | 88 | val bash_functionN: string | 
| 89 | val scala_functionN: string | |
| 56465 | 90 | val system_optionN: string | 
| 67219 | 91 | val sessionN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 92 | val theoryN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 93 | val classN: string | 
| 74112 | 94 | val localeN: string | 
| 74261 
d28a51dd9da6
export other entities, e.g. relevant for formal document output;
 wenzelm parents: 
74182diff
changeset | 95 | val bundleN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 96 | val type_nameN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 97 | val constantN: string | 
| 74112 | 98 | val axiomN: string | 
| 99 | val factN: string | |
| 100 | val oracleN: string | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 101 | val fixedN: string val fixed: string -> T | 
| 53378 
07990ba8c0ea
cases: more position information and PIDE markup;
 wenzelm parents: 
53055diff
changeset | 102 | val caseN: string val case_: string -> T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 103 | val dynamic_factN: string val dynamic_fact: string -> T | 
| 63337 | 104 | val literal_factN: string val literal_fact: string -> T | 
| 74112 | 105 | val attributeN: string | 
| 106 | val methodN: string | |
| 58048 
aa6296d09e0e
more explicit Method.modifier with reported position;
 wenzelm parents: 
57975diff
changeset | 107 | val method_modifierN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 108 | val tfreeN: string val tfree: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 109 | val tvarN: string val tvar: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 110 | val freeN: string val free: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 111 | val skolemN: string val skolem: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 112 | val boundN: string val bound: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 113 | val varN: string val var: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 114 | val numeralN: string val numeral: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 115 | val literalN: string val literal: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 116 | val delimiterN: string val delimiter: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 117 | val inner_stringN: string val inner_string: T | 
| 55033 | 118 | val inner_cartoucheN: string val inner_cartouche: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 119 | val token_rangeN: string val token_range: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 120 | val sortingN: string val sorting: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 121 | val typingN: string val typing: T | 
| 63347 | 122 | val class_parameterN: string val class_parameter: T | 
| 55505 | 123 | val ML_keyword1N: string val ML_keyword1: T | 
| 124 | val ML_keyword2N: string val ML_keyword2: T | |
| 125 | val ML_keyword3N: string val ML_keyword3: T | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 126 | val ML_delimiterN: string val ML_delimiter: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 127 | val ML_tvarN: string val ML_tvar: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 128 | val ML_numeralN: string val ML_numeral: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 129 | val ML_charN: string val ML_char: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 130 | val ML_stringN: string val ML_string: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 131 | val ML_commentN: string val ML_comment: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 132 | val ML_defN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 133 | val ML_openN: string | 
| 55837 | 134 | val ML_structureN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 135 | val ML_typingN: string val ML_typing: T | 
| 60744 | 136 | val ML_breakpointN: string val ML_breakpoint: int -> T | 
| 55526 | 137 | val antiquotedN: string val antiquoted: T | 
| 138 | val antiquoteN: string val antiquote: T | |
| 69381 
4c9b4e2c5460
more general command 'generate_file' for registered file types, notably Haskell;
 wenzelm parents: 
69345diff
changeset | 139 | val file_typeN: string | 
| 
4c9b4e2c5460
more general command 'generate_file' for registered file types, notably Haskell;
 wenzelm parents: 
69345diff
changeset | 140 | val antiquotationN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 141 | val ML_antiquotationN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 142 | val document_antiquotationN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 143 | val document_antiquotation_optionN: string | 
| 69965 
da5e7278286b
more markup for various text kinds, notably for nested formal comments;
 wenzelm parents: 
69962diff
changeset | 144 | val raw_textN: string val raw_text: T | 
| 
da5e7278286b
more markup for various text kinds, notably for nested formal comments;
 wenzelm parents: 
69962diff
changeset | 145 | val plain_textN: string val plain_text: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 146 | val paragraphN: string val paragraph: T | 
| 50545 
00bdc48c5f71
explicit text_fold markup, which is used by default in Pretty.chunks/chunks2;
 wenzelm parents: 
50543diff
changeset | 147 | val text_foldN: string val text_fold: T | 
| 70229 | 148 | val document_markerN: string val document_marker: T | 
| 70135 
ad6d4a14adb5
report document tags as seen in the text (not the active tag of Thy_Output.present_thy);
 wenzelm parents: 
70016diff
changeset | 149 | val document_tagN: string val document_tag: string -> T | 
| 73780 
466fae6bf22e
compose Latex text as XML, output exported YXML in Isabelle/Scala;
 wenzelm parents: 
73419diff
changeset | 150 | val document_latexN: string val document_latex: T | 
| 61449 | 151 | val markdown_paragraphN: string val markdown_paragraph: T | 
| 67323 
d02208cefbdb
PIDE markup for Markdown items (which may consist of multiple paragraphs or lists);
 wenzelm parents: 
67322diff
changeset | 152 | val markdown_itemN: string val markdown_item: T | 
| 67336 | 153 | val markdown_bulletN: string val markdown_bullet: int -> T | 
| 61449 | 154 | val markdown_listN: string val markdown_list: string -> T | 
| 67336 | 155 | val itemizeN: string | 
| 156 | val enumerateN: string | |
| 157 | val descriptionN: string | |
| 59795 | 158 | val inputN: string val input: bool -> Properties.T -> T | 
| 59935 | 159 | val command_keywordN: string val command_keyword: T | 
| 66066 | 160 | val commandN: string val command_properties: T -> T | 
| 161 | val keywordN: string val keyword_properties: T -> T | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 162 | val stringN: string val string: T | 
| 59081 | 163 | val alt_stringN: string val alt_string: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 164 | val verbatimN: string val verbatim: T | 
| 55033 | 165 | val cartoucheN: string val cartouche: T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 166 | val commentN: string val comment: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 167 | val keyword1N: string val keyword1: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 168 | val keyword2N: string val keyword2: T | 
| 55763 | 169 | val keyword3N: string val keyword3: T | 
| 55919 
2eb8c13339a5
more explicit quasi_keyword markup, for Args.$$$ material, which is somewhere in between of outer and inner syntax;
 wenzelm parents: 
55914diff
changeset | 170 | val quasi_keywordN: string val quasi_keyword: T | 
| 56202 | 171 | val improperN: string val improper: T | 
| 172 | val operatorN: string val operator: T | |
| 69320 | 173 | val comment1N: string val comment1: T | 
| 174 | val comment2N: string val comment2: T | |
| 175 | val comment3N: string val comment3: T | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 176 | val elapsedN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 177 | val cpuN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 178 | val gcN: string | 
| 51606 
2843cc095a57
additional timing status for implicitly forked terminal proofs -- proper accounting for interactive Timing dockable etc.;
 wenzelm parents: 
51570diff
changeset | 179 |   val timing_properties: {elapsed: Time.time, cpu: Time.time, gc: Time.time} -> Properties.T
 | 
| 51228 | 180 | val parse_command_timing_properties: | 
| 181 |     Properties.T -> ({file: string, offset: int, name: string} * Time.time) option
 | |
| 51606 
2843cc095a57
additional timing status for implicitly forked terminal proofs -- proper accounting for interactive Timing dockable etc.;
 wenzelm parents: 
51570diff
changeset | 182 |   val timingN: string val timing: {elapsed: Time.time, cpu: Time.time, gc: Time.time} -> T
 | 
| 63474 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 183 | val command_indentN: string val command_indent: int -> T | 
| 50543 | 184 | val goalN: string val goal: T | 
| 50537 
08ce81aeeacc
more subgoal markup information, which is potentially useful to manage proof state output;
 wenzelm parents: 
50503diff
changeset | 185 | val subgoalN: string val subgoal: string -> T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 186 | val taskN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 187 | val forkedN: string val forked: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 188 | val joinedN: string val joined: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 189 | val runningN: string val running: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 190 | val finishedN: string val finished: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 191 | val failedN: string val failed: T | 
| 68871 
f5c76072db55
more explicit status for "canceled" command within theory node;
 wenzelm parents: 
68822diff
changeset | 192 | val canceledN: string val canceled: T | 
| 68323 | 193 | val initializedN: string val initialized: T | 
| 68884 
9b97d0b20d95
clarified quasi_consolidated state: ensure that exports are present for ok nodes;
 wenzelm parents: 
68871diff
changeset | 194 | val finalizedN: string val finalized: T | 
| 70780 
034742453594
more robust: avoid update/interrupt of long-running print_consolidation;
 wenzelm parents: 
70665diff
changeset | 195 | val consolidatingN: string val consolidating: T | 
| 66379 
6392766f3c25
maintain "consolidated" status of theory nodes, which means all evals are finished (but not necessarily prints nor imports);
 wenzelm parents: 
66066diff
changeset | 196 | val consolidatedN: string val consolidated: T | 
| 50914 
fe4714886d92
identify future results more carefully, to avoid odd duplication of error messages, notably from forked goals;
 wenzelm parents: 
50845diff
changeset | 197 | val exec_idN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 198 | val initN: string | 
| 61209 | 199 | val statusN: string val status: T | 
| 200 | val resultN: string val result: T | |
| 201 | val writelnN: string val writeln: T | |
| 202 | val stateN: string val state: T | |
| 203 | val informationN: string val information: T | |
| 204 | val tracingN: string val tracing: T | |
| 205 | val warningN: string val warning: T | |
| 206 | val legacyN: string val legacy: T | |
| 207 | val errorN: string val error: T | |
| 208 | val systemN: string val system: T | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 209 | val protocolN: string | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 210 | val reportN: string val report: T | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 211 | val no_reportN: string val no_report: T | 
| 64677 
8dc24130e8fe
more uniform treatment of "bad" like other messages (with serial number);
 wenzelm parents: 
63806diff
changeset | 212 | val badN: string val bad: unit -> T | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 213 | val intensifyN: string val intensify: T | 
| 73835 | 214 | val countN: string | 
| 215 | val ML_profiling_entryN: string | |
| 216 |   val ML_profiling_entry: {name: string, count: int} -> T
 | |
| 217 | val ML_profilingN: string | |
| 218 | val ML_profiling: string -> T | |
| 50715 
8cfd585b9162
prefer old graph browser in Isabelle/jEdit, which still produces better layout;
 wenzelm parents: 
50683diff
changeset | 219 | val browserN: string | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 220 | val graphviewN: string | 
| 69650 | 221 | val theory_exportsN: string | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 222 | val sendbackN: string | 
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 223 | val paddingN: string | 
| 50842 | 224 | val padding_line: Properties.entry | 
| 52697 
6fb98a20c349
explicit padding on command boundary for "auto" generated sendback -- do not replace the corresponding goal command, but append to it;
 wenzelm parents: 
52643diff
changeset | 225 | val padding_command: Properties.entry | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 226 | val dialogN: string val dialog: serial -> string -> T | 
| 63681 | 227 | val jedit_actionN: string | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 228 | val functionN: string | 
| 72119 
d115d50a19c0
provide POLYSTATSDIR to keep $HOME/.polyml clean (requires Poly/ML 52881757b127, otherwise ignored);
 wenzelm parents: 
72116diff
changeset | 229 |   val ML_statistics: {pid: int, stats_dir: string} -> Properties.T
 | 
| 70665 
94442fce40a5
prefer commands_accepted: fewer protocol messages;
 wenzelm parents: 
70499diff
changeset | 230 | val commands_accepted: Properties.T | 
| 52563 | 231 | val assign_update: Properties.T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 232 | val removed_versions: Properties.T | 
| 73419 
22f3f2117ed7
clarified signature: function_thread is determined in Isabelle/Scala, not Isabelle/ML;
 wenzelm parents: 
72861diff
changeset | 233 | val invoke_scala: string -> string -> Properties.T | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 234 | val cancel_scala: string -> Properties.T | 
| 50975 | 235 | val task_statistics: Properties.entry | 
| 51216 | 236 | val command_timing: Properties.entry | 
| 66873 
9953ae603a23
provide theory timing information, similar to command timing but always considered relevant;
 wenzelm parents: 
66379diff
changeset | 237 | val theory_timing: Properties.entry | 
| 72002 
5c4800f6b25a
more robust protocol for "Timing ..." messages, notably for pide_session=true;
 wenzelm parents: 
71912diff
changeset | 238 | val session_timing: Properties.entry | 
| 50845 | 239 | val loading_theory: string -> Properties.T | 
| 65313 | 240 | val build_session_finished: Properties.T | 
| 56864 | 241 | val print_operationsN: string | 
| 242 | val print_operations: Properties.T | |
| 69788 | 243 | val exportN: string | 
| 244 | type export_args = | |
| 245 |    {id: string option,
 | |
| 246 | serial: serial, | |
| 247 | theory_name: string, | |
| 248 | name: string, | |
| 249 | executable: bool, | |
| 70499 | 250 | compress: bool, | 
| 251 | strict: bool} | |
| 69788 | 252 | val export: export_args -> Properties.T | 
| 60842 | 253 | val debugger_state: string -> Properties.T | 
| 60834 | 254 | val debugger_output: string -> Properties.T | 
| 57594 
037f3b251df5
regular message to refer to Simplifier Trace panel (unused);
 wenzelm parents: 
56864diff
changeset | 255 | val simp_trace_panelN: string | 
| 55553 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 256 | val simp_trace_logN: string | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 257 | val simp_trace_stepN: string | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 258 | val simp_trace_recurseN: string | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 259 | val simp_trace_hintN: string | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 260 | val simp_trace_ignoreN: string | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 261 | val simp_trace_cancel: serial -> Properties.T | 
| 69345 
6bd63c94cf62
tuned signature (see also src/Tools/Haskell/Markup.hs);
 wenzelm parents: 
69320diff
changeset | 262 | type output = Output.output * Output.output | 
| 
6bd63c94cf62
tuned signature (see also src/Tools/Haskell/Markup.hs);
 wenzelm parents: 
69320diff
changeset | 263 | val no_output: output | 
| 
6bd63c94cf62
tuned signature (see also src/Tools/Haskell/Markup.hs);
 wenzelm parents: 
69320diff
changeset | 264 | val add_mode: string -> (T -> output) -> unit | 
| 
6bd63c94cf62
tuned signature (see also src/Tools/Haskell/Markup.hs);
 wenzelm parents: 
69320diff
changeset | 265 | val output: T -> output | 
| 40131 
7cbebd636e79
explicitly qualify type Output.output, which is a slightly odd internal feature;
 wenzelm parents: 
39585diff
changeset | 266 | val enclose: T -> Output.output -> Output.output | 
| 25552 | 267 | val markup: T -> string -> string | 
| 59125 | 268 | val markups: T list -> string -> string | 
| 43665 | 269 | val markup_only: T -> string | 
| 55956 
94d384d621b0
reject internal term names outright, and complete consts instead;
 wenzelm parents: 
55919diff
changeset | 270 | val markup_report: string -> string | 
| 23623 | 271 | end; | 
| 272 | ||
| 273 | structure Markup: MARKUP = | |
| 274 | struct | |
| 275 | ||
| 30221 | 276 | (** markup elements **) | 
| 277 | ||
| 23658 | 278 | (* basic markup *) | 
| 23623 | 279 | |
| 28017 | 280 | type T = string * Properties.T; | 
| 23637 | 281 | |
| 38474 
e498dc2eb576
uniform Markup.empty/Markup.Empty in ML and Scala;
 wenzelm parents: 
38429diff
changeset | 282 | val empty = ("", []);
 | 
| 23637 | 283 | |
| 38474 
e498dc2eb576
uniform Markup.empty/Markup.Empty in ML and Scala;
 wenzelm parents: 
38429diff
changeset | 284 | fun is_empty ("", _) = true
 | 
| 
e498dc2eb576
uniform Markup.empty/Markup.Empty in ML and Scala;
 wenzelm parents: 
38429diff
changeset | 285 | | is_empty _ = false; | 
| 27883 | 286 | |
| 23794 | 287 | |
| 23671 | 288 | fun properties more_props ((elem, props): T) = | 
| 28017 | 289 | (elem, fold_rev Properties.put more_props props); | 
| 23671 | 290 | |
| 55551 | 291 | fun markup_elem name = (name, (name, []): T); | 
| 292 | fun markup_string name prop = (name, fn s => (name, [(prop, s)]): T); | |
| 63806 | 293 | fun markup_int name prop = (name, fn i => (name, [(prop, Value.print_int i)]): T); | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 294 | |
| 26977 | 295 | |
| 38721 
ca8b14fa0d0d
added some proof state markup, notably number of subgoals (e.g. for indentation);
 wenzelm parents: 
38474diff
changeset | 296 | (* misc properties *) | 
| 26977 | 297 | |
| 23658 | 298 | val nameN = "name"; | 
| 27818 | 299 | fun name a = properties [(nameN, a)]; | 
| 300 | ||
| 68997 | 301 | val xnameN = "xname"; | 
| 302 | fun xname a = properties [(xnameN, a)]; | |
| 303 | ||
| 23658 | 304 | val kindN = "kind"; | 
| 23671 | 305 | |
| 60744 | 306 | val serialN = "serial"; | 
| 63806 | 307 | fun serial_properties i = [(serialN, Value.print_int i)]; | 
| 60744 | 308 | |
| 52854 
92932931bd82
more general Output.result: allow to update arbitrary properties;
 wenzelm parents: 
52800diff
changeset | 309 | val instanceN = "instance"; | 
| 
92932931bd82
more general Output.result: allow to update arbitrary properties;
 wenzelm parents: 
52800diff
changeset | 310 | |
| 23658 | 311 | |
| 69962 
82e945d472d5
documentation of document markers and re-interpreted command tags;
 wenzelm parents: 
69916diff
changeset | 312 | (* meta data -- see https://www.dublincore.org/specifications/dublin-core/dcmi-terms *) | 
| 69889 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 313 | |
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 314 | val (meta_titleN, meta_title) = markup_elem "meta_title"; | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 315 | val (meta_creatorN, meta_creator) = markup_elem "meta_creator"; | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 316 | val (meta_contributorN, meta_contributor) = markup_elem "meta_contributor"; | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 317 | val (meta_dateN, meta_date) = markup_elem "meta_date"; | 
| 69962 
82e945d472d5
documentation of document markers and re-interpreted command tags;
 wenzelm parents: 
69916diff
changeset | 318 | val (meta_licenseN, meta_license) = markup_elem "meta_license"; | 
| 69889 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 319 | val (meta_descriptionN, meta_description) = markup_elem "meta_description"; | 
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 320 | |
| 
be04e9a053a7
markup and document markers for some meta data from "Dublin Core Metadata Element Set";
 wenzelm parents: 
69887diff
changeset | 321 | |
| 55550 | 322 | (* embedded languages *) | 
| 323 | ||
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 324 | val languageN = "language"; | 
| 55615 
bf4bbe72f740
completion of keywords and symbols based on language context;
 wenzelm parents: 
55613diff
changeset | 325 | val symbolsN = "symbols"; | 
| 55666 | 326 | val antiquotesN = "antiquotes"; | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 327 | val delimitedN = "delimited" | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 328 | |
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 329 | fun is_delimited props = | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 330 | Properties.get props delimitedN = SOME "true"; | 
| 55666 | 331 | |
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 332 | fun language {name, symbols, antiquotes, delimited} =
 | 
| 55666 | 333 | (languageN, | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 334 | [(nameN, name), | 
| 63806 | 335 | (symbolsN, Value.print_bool symbols), | 
| 336 | (antiquotesN, Value.print_bool antiquotes), | |
| 337 | (delimitedN, Value.print_bool delimited)]); | |
| 55550 | 338 | |
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 339 | fun language' {name, symbols, antiquotes} delimited =
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 340 |   language {name = name, symbols = symbols, antiquotes = antiquotes, delimited = delimited};
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 341 | |
| 62231 
25f4a9cd8b68
tuned markup, e.g. relevant for Rendering.tooltip;
 wenzelm parents: 
61864diff
changeset | 342 | val language_Isar = language' {name = "Isar", symbols = true, antiquotes = false};
 | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 343 | val language_method = | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 344 |   language {name = "method", symbols = true, antiquotes = false, delimited = false};
 | 
| 56033 | 345 | val language_attribute = | 
| 346 |   language {name = "attribute", symbols = true, antiquotes = false, delimited = false};
 | |
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 347 | val language_sort = language' {name = "sort", symbols = true, antiquotes = false};
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 348 | val language_type = language' {name = "type", symbols = true, antiquotes = false};
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 349 | val language_term = language' {name = "term", symbols = true, antiquotes = false};
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 350 | val language_prop = language' {name = "prop", symbols = true, antiquotes = false};
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 351 | val language_ML = language' {name = "ML", symbols = false, antiquotes = true};
 | 
| 56278 
2576d3a40ed6
separate tokenization and language context for SML: no symbols, no antiquotes;
 wenzelm parents: 
56202diff
changeset | 352 | val language_SML = language' {name = "SML", symbols = false, antiquotes = false};
 | 
| 61600 
1ca11ddfcc70
clarified completion of explicit symbols (see also f6bd97a587b7, e0e4ac981cf1);
 wenzelm parents: 
61598diff
changeset | 353 | val language_document = language' {name = "document", symbols = false, antiquotes = true};
 | 
| 69887 | 354 | val language_document_marker = | 
| 355 |   language {name = "document_marker", symbols = true, antiquotes = true, delimited = true};
 | |
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 356 | val language_antiquotation = | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 357 |   language {name = "antiquotation", symbols = true, antiquotes = false, delimited = true};
 | 
| 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 358 | val language_text = language' {name = "text", symbols = true, antiquotes = false};
 | 
| 62772 | 359 | val language_verbatim = language' {name = "verbatim_text", symbols = true, antiquotes = false};
 | 
| 67429 | 360 | val language_latex = language' {name = "latex", symbols = false, antiquotes = false};
 | 
| 55828 
42ac3cfb89f6
clarified language markup: added "delimited" property;
 wenzelm parents: 
55763diff
changeset | 361 | val language_rail = language {name = "rail", symbols = true, antiquotes = true, delimited = true};
 | 
| 72841 | 362 | val language_path = language' {name = "path", symbols = false, antiquotes = false};
 | 
| 72843 | 363 | val language_url = language' {name = "url", symbols = false, antiquotes = false};
 | 
| 62772 | 364 | val language_mixfix = | 
| 365 |   language {name = "mixfix_annotation", symbols = true, antiquotes = false, delimited = true};
 | |
| 55550 | 366 | |
| 367 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 368 | (* formal entities *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 369 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 370 | val (bindingN, binding) = markup_elem "binding"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 371 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 372 | val entityN = "entity"; | 
| 63337 | 373 | fun entity kind name = | 
| 374 | (entityN, | |
| 375 | (if name = "" then [] else [(nameN, name)]) @ (if kind = "" then [] else [(kindN, kind)])); | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 376 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 377 | val defN = "def"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 378 | val refN = "ref"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 379 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 380 | |
| 55672 
5e25cc741ab9
support for completion within the formal context;
 wenzelm parents: 
55666diff
changeset | 381 | (* completion *) | 
| 
5e25cc741ab9
support for completion within the formal context;
 wenzelm parents: 
55666diff
changeset | 382 | |
| 55694 
a1184dfb8e00
clarified semantic completion: retain kind.full_name as official item name for history;
 wenzelm parents: 
55687diff
changeset | 383 | val (completionN, completion) = markup_elem "completion"; | 
| 55914 
c5b752d549e3
clarified init_assignable: make double-sure that initial values are reset;
 wenzelm parents: 
55837diff
changeset | 384 | val (no_completionN, no_completion) = markup_elem "no_completion"; | 
| 55672 
5e25cc741ab9
support for completion within the formal context;
 wenzelm parents: 
55666diff
changeset | 385 | |
| 69557 | 386 | val (updateN, update) = markup_elem "update"; | 
| 387 | ||
| 55672 
5e25cc741ab9
support for completion within the formal context;
 wenzelm parents: 
55666diff
changeset | 388 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 389 | (* position *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 390 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 391 | val lineN = "line"; | 
| 58978 
e42da880c61e
more position information, e.g. relevant for errors in generated ML source;
 wenzelm parents: 
58855diff
changeset | 392 | val end_lineN = "end_line"; | 
| 
e42da880c61e
more position information, e.g. relevant for errors in generated ML source;
 wenzelm parents: 
58855diff
changeset | 393 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 394 | val offsetN = "offset"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 395 | val end_offsetN = "end_offset"; | 
| 58978 
e42da880c61e
more position information, e.g. relevant for errors in generated ML source;
 wenzelm parents: 
58855diff
changeset | 396 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 397 | val fileN = "file"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 398 | val idN = "id"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 399 | |
| 74182 | 400 | val (positionN, position) = markup_elem "position"; | 
| 401 | ||
| 72707 | 402 | val position_properties = [lineN, offsetN, end_offsetN, fileN, idN]; | 
| 72708 | 403 | fun position_property (entry: Properties.entry) = member (op =) position_properties (#1 entry); | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 404 | |
| 74182 | 405 | |
| 406 | (* position "def" names *) | |
| 407 | ||
| 408 | fun make_def a = "def_" ^ a; | |
| 409 | ||
| 410 | val def_names = Symtab.make (map (fn a => (a, make_def a)) position_properties); | |
| 411 | ||
| 412 | fun def_name a = | |
| 413 | (case Symtab.lookup def_names a of | |
| 414 | SOME b => b | |
| 415 | | NONE => make_def a); | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 416 | |
| 74263 
be49c660ebbf
more markup, e.g. to locate defining theory node in formal document output;
 wenzelm parents: 
74261diff
changeset | 417 | val def_theoryN = "def_theory"; | 
| 
be49c660ebbf
more markup, e.g. to locate defining theory node in formal document output;
 wenzelm parents: 
74261diff
changeset | 418 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 419 | |
| 58464 | 420 | (* expression *) | 
| 421 | ||
| 62806 | 422 | val expressionN = "expression"; | 
| 423 | fun expression kind = (expressionN, if kind = "" then [] else [(kindN, kind)]); | |
| 58464 | 424 | |
| 425 | ||
| 58544 
340f130b3d38
bibtex support in ML: document antiquotation @{cite} with markup;
 wenzelm parents: 
58464diff
changeset | 426 | (* citation *) | 
| 
340f130b3d38
bibtex support in ML: document antiquotation @{cite} with markup;
 wenzelm parents: 
58464diff
changeset | 427 | |
| 58545 
30b75b7958d6
citation tooltip/hyperlink based on open buffers with .bib files;
 wenzelm parents: 
58544diff
changeset | 428 | val (citationN, citation) = markup_string "citation" nameN; | 
| 58544 
340f130b3d38
bibtex support in ML: document antiquotation @{cite} with markup;
 wenzelm parents: 
58464diff
changeset | 429 | |
| 
340f130b3d38
bibtex support in ML: document antiquotation @{cite} with markup;
 wenzelm parents: 
58464diff
changeset | 430 | |
| 54702 
3daeba5130f0
added document antiquotation @{url}, which produces formal markup for LaTeX and PIDE;
 wenzelm parents: 
53378diff
changeset | 431 | (* external resources *) | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 432 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 433 | val (pathN, path) = markup_string "path" nameN; | 
| 70016 | 434 | val (export_pathN, export_path) = markup_string "export_path" nameN; | 
| 54702 
3daeba5130f0
added document antiquotation @{url}, which produces formal markup for LaTeX and PIDE;
 wenzelm parents: 
53378diff
changeset | 435 | val (urlN, url) = markup_string "url" nameN; | 
| 61660 
78b371644654
added antiquotation @{doc}, e.g. useful for demonstration purposes;
 wenzelm parents: 
61614diff
changeset | 436 | val (docN, doc) = markup_string "doc" nameN; | 
| 72763 | 437 | val (toolN, tool) = markup_string "tool" nameN; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 438 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 439 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 440 | (* pretty printing *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 441 | |
| 62783 | 442 | val markupN = "markup"; | 
| 62786 | 443 | val consistentN = "consistent"; | 
| 62789 | 444 | val unbreakableN = "unbreakable"; | 
| 62786 | 445 | val indentN = "indent"; | 
| 446 | ||
| 62789 | 447 | val block_properties = [markupN, consistentN, unbreakableN, indentN]; | 
| 62786 | 448 | |
| 61864 | 449 | val widthN = "width"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 450 | |
| 61864 | 451 | val blockN = "block"; | 
| 452 | fun block c i = | |
| 453 | (blockN, | |
| 63806 | 454 | (if c then [(consistentN, Value.print_bool c)] else []) @ | 
| 455 | (if i <> 0 then [(indentN, Value.print_int i)] else [])); | |
| 61864 | 456 | |
| 61862 
e2a9e46ac0fb
support pretty break indent, like underlying ML systems;
 wenzelm parents: 
61660diff
changeset | 457 | val breakN = "break"; | 
| 61864 | 458 | fun break w i = | 
| 459 | (breakN, | |
| 63806 | 460 | (if w <> 0 then [(widthN, Value.print_int w)] else []) @ | 
| 461 | (if i <> 0 then [(indentN, Value.print_int i)] else [])); | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 462 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 463 | val (fbreakN, fbreak) = markup_elem "fbreak"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 464 | |
| 51570 
3633828d80fc
basic support for Pretty.item, which is considered as logical markup and interpreted in Isabelle/Scala, but ignored elsewhere (TTY, latex etc.);
 wenzelm parents: 
51228diff
changeset | 465 | val (itemN, item) = markup_elem "item"; | 
| 
3633828d80fc
basic support for Pretty.item, which is considered as logical markup and interpreted in Isabelle/Scala, but ignored elsewhere (TTY, latex etc.);
 wenzelm parents: 
51228diff
changeset | 466 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 467 | |
| 56548 | 468 | (* text properties *) | 
| 469 | ||
| 470 | val (wordsN, words) = markup_elem "words"; | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 471 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 472 | val (hiddenN, hidden) = markup_elem "hidden"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 473 | |
| 68298 
2c3ce27cf4a8
markup for deleted fragments of token source (NB: quoted tokens transform "\123" implicitly);
 wenzelm parents: 
68101diff
changeset | 474 | val (deleteN, delete) = markup_elem "delete"; | 
| 
2c3ce27cf4a8
markup for deleted fragments of token source (NB: quoted tokens transform "\123" implicitly);
 wenzelm parents: 
68101diff
changeset | 475 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 476 | |
| 58048 
aa6296d09e0e
more explicit Method.modifier with reported position;
 wenzelm parents: 
57975diff
changeset | 477 | (* misc entities *) | 
| 56465 | 478 | |
| 71912 | 479 | val bash_functionN = "bash_function"; | 
| 480 | val scala_functionN = "scala_function"; | |
| 56465 | 481 | val system_optionN = "system_option"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 482 | |
| 67219 | 483 | val sessionN = "session"; | 
| 484 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 485 | val theoryN = "theory"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 486 | val classN = "class"; | 
| 74112 | 487 | val localeN = "locale"; | 
| 74261 
d28a51dd9da6
export other entities, e.g. relevant for formal document output;
 wenzelm parents: 
74182diff
changeset | 488 | val bundleN = "bundle"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 489 | val type_nameN = "type_name"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 490 | val constantN = "constant"; | 
| 74112 | 491 | val axiomN = "axiom"; | 
| 492 | val factN = "fact"; | |
| 493 | val oracleN = "oracle"; | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 494 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 495 | val (fixedN, fixed) = markup_string "fixed" nameN; | 
| 53378 
07990ba8c0ea
cases: more position information and PIDE markup;
 wenzelm parents: 
53055diff
changeset | 496 | val (caseN, case_) = markup_string "case" nameN; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 497 | val (dynamic_factN, dynamic_fact) = markup_string "dynamic_fact" nameN; | 
| 63337 | 498 | val (literal_factN, literal_fact) = markup_string "literal_fact" nameN; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 499 | |
| 74112 | 500 | val attributeN = "attribute"; | 
| 501 | val methodN = "method"; | |
| 58048 
aa6296d09e0e
more explicit Method.modifier with reported position;
 wenzelm parents: 
57975diff
changeset | 502 | val method_modifierN = "method_modifier"; | 
| 
aa6296d09e0e
more explicit Method.modifier with reported position;
 wenzelm parents: 
57975diff
changeset | 503 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 504 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 505 | (* inner syntax *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 506 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 507 | val (tfreeN, tfree) = markup_elem "tfree"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 508 | val (tvarN, tvar) = markup_elem "tvar"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 509 | val (freeN, free) = markup_elem "free"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 510 | val (skolemN, skolem) = markup_elem "skolem"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 511 | val (boundN, bound) = markup_elem "bound"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 512 | val (varN, var) = markup_elem "var"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 513 | val (numeralN, numeral) = markup_elem "numeral"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 514 | val (literalN, literal) = markup_elem "literal"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 515 | val (delimiterN, delimiter) = markup_elem "delimiter"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 516 | val (inner_stringN, inner_string) = markup_elem "inner_string"; | 
| 55033 | 517 | val (inner_cartoucheN, inner_cartouche) = markup_elem "inner_cartouche"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 518 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 519 | val (token_rangeN, token_range) = markup_elem "token_range"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 520 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 521 | val (sortingN, sorting) = markup_elem "sorting"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 522 | val (typingN, typing) = markup_elem "typing"; | 
| 63347 | 523 | val (class_parameterN, class_parameter) = markup_elem "class_parameter"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 524 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 525 | |
| 60744 | 526 | (* ML *) | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 527 | |
| 55505 | 528 | val (ML_keyword1N, ML_keyword1) = markup_elem "ML_keyword1"; | 
| 529 | val (ML_keyword2N, ML_keyword2) = markup_elem "ML_keyword2"; | |
| 530 | val (ML_keyword3N, ML_keyword3) = markup_elem "ML_keyword3"; | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 531 | val (ML_delimiterN, ML_delimiter) = markup_elem "ML_delimiter"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 532 | val (ML_tvarN, ML_tvar) = markup_elem "ML_tvar"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 533 | val (ML_numeralN, ML_numeral) = markup_elem "ML_numeral"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 534 | val (ML_charN, ML_char) = markup_elem "ML_char"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 535 | val (ML_stringN, ML_string) = markup_elem "ML_string"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 536 | val (ML_commentN, ML_comment) = markup_elem "ML_comment"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 537 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 538 | val ML_defN = "ML_def"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 539 | val ML_openN = "ML_open"; | 
| 55837 | 540 | val ML_structureN = "ML_structure"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 541 | val (ML_typingN, ML_typing) = markup_elem "ML_typing"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 542 | |
| 60744 | 543 | val (ML_breakpointN, ML_breakpoint) = markup_int "ML_breakpoint" serialN; | 
| 544 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 545 | |
| 55550 | 546 | (* antiquotations *) | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 547 | |
| 55526 | 548 | val (antiquotedN, antiquoted) = markup_elem "antiquoted"; | 
| 549 | val (antiquoteN, antiquote) = markup_elem "antiquote"; | |
| 550 | ||
| 69381 
4c9b4e2c5460
more general command 'generate_file' for registered file types, notably Haskell;
 wenzelm parents: 
69345diff
changeset | 551 | val file_typeN = "file_type"; | 
| 
4c9b4e2c5460
more general command 'generate_file' for registered file types, notably Haskell;
 wenzelm parents: 
69345diff
changeset | 552 | val antiquotationN = "antiquotation"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 553 | val ML_antiquotationN = "ML_antiquotation"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 554 | val document_antiquotationN = "document_antiquotation"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 555 | val document_antiquotation_optionN = "document_antiquotation_option"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 556 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 557 | |
| 70135 
ad6d4a14adb5
report document tags as seen in the text (not the active tag of Thy_Output.present_thy);
 wenzelm parents: 
70016diff
changeset | 558 | (* document text *) | 
| 69965 
da5e7278286b
more markup for various text kinds, notably for nested formal comments;
 wenzelm parents: 
69962diff
changeset | 559 | |
| 
da5e7278286b
more markup for various text kinds, notably for nested formal comments;
 wenzelm parents: 
69962diff
changeset | 560 | val (raw_textN, raw_text) = markup_elem "raw_text"; | 
| 
da5e7278286b
more markup for various text kinds, notably for nested formal comments;
 wenzelm parents: 
69962diff
changeset | 561 | val (plain_textN, plain_text) = markup_elem "plain_text"; | 
| 
da5e7278286b
more markup for various text kinds, notably for nested formal comments;
 wenzelm parents: 
69962diff
changeset | 562 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 563 | val (paragraphN, paragraph) = markup_elem "paragraph"; | 
| 50545 
00bdc48c5f71
explicit text_fold markup, which is used by default in Pretty.chunks/chunks2;
 wenzelm parents: 
50543diff
changeset | 564 | val (text_foldN, text_fold) = markup_elem "text_fold"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 565 | |
| 70229 | 566 | val (document_markerN, document_marker) = markup_elem "document_marker"; | 
| 70135 
ad6d4a14adb5
report document tags as seen in the text (not the active tag of Thy_Output.present_thy);
 wenzelm parents: 
70016diff
changeset | 567 | val (document_tagN, document_tag) = markup_string "document_tag" nameN; | 
| 
ad6d4a14adb5
report document tags as seen in the text (not the active tag of Thy_Output.present_thy);
 wenzelm parents: 
70016diff
changeset | 568 | |
| 73780 
466fae6bf22e
compose Latex text as XML, output exported YXML in Isabelle/Scala;
 wenzelm parents: 
73419diff
changeset | 569 | val (document_latexN, document_latex) = markup_elem "document_latex"; | 
| 
466fae6bf22e
compose Latex text as XML, output exported YXML in Isabelle/Scala;
 wenzelm parents: 
73419diff
changeset | 570 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 571 | |
| 61449 | 572 | (* Markdown document structure *) | 
| 573 | ||
| 574 | val (markdown_paragraphN, markdown_paragraph) = markup_elem "markdown_paragraph"; | |
| 67323 
d02208cefbdb
PIDE markup for Markdown items (which may consist of multiple paragraphs or lists);
 wenzelm parents: 
67322diff
changeset | 575 | val (markdown_itemN, markdown_item) = markup_elem "markdown_item"; | 
| 67336 | 576 | val (markdown_bulletN, markdown_bullet) = markup_int "markdown_bullet" "depth"; | 
| 61449 | 577 | val (markdown_listN, markdown_list) = markup_string "markdown_list" kindN; | 
| 67336 | 578 | |
| 579 | val itemizeN = "itemize"; | |
| 580 | val enumerateN = "enumerate"; | |
| 581 | val descriptionN = "description"; | |
| 61449 | 582 | |
| 583 | ||
| 59795 | 584 | (* formal input *) | 
| 585 | ||
| 586 | val inputN = "input"; | |
| 63806 | 587 | fun input delimited props = (inputN, (delimitedN, Value.print_bool delimited) :: props); | 
| 59795 | 588 | |
| 589 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 590 | (* outer syntax *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 591 | |
| 59935 | 592 | val (command_keywordN, command_keyword) = markup_elem "command_keyword"; | 
| 66044 | 593 | |
| 66066 | 594 | val commandN = "command"; val command_properties = properties [(kindN, commandN)]; | 
| 595 | val keywordN = "keyword"; val keyword_properties = properties [(kindN, keywordN)]; | |
| 596 | ||
| 55744 
4a4e5686e091
clarified token markup: keyword1/keyword2 is for syntax, and "command" the entity kind;
 wenzelm parents: 
55694diff
changeset | 597 | val (keyword1N, keyword1) = markup_elem "keyword1"; | 
| 
4a4e5686e091
clarified token markup: keyword1/keyword2 is for syntax, and "command" the entity kind;
 wenzelm parents: 
55694diff
changeset | 598 | val (keyword2N, keyword2) = markup_elem "keyword2"; | 
| 55763 | 599 | val (keyword3N, keyword3) = markup_elem "keyword3"; | 
| 55919 
2eb8c13339a5
more explicit quasi_keyword markup, for Args.$$$ material, which is somewhere in between of outer and inner syntax;
 wenzelm parents: 
55914diff
changeset | 600 | val (quasi_keywordN, quasi_keyword) = markup_elem "quasi_keyword"; | 
| 56202 | 601 | val (improperN, improper) = markup_elem "improper"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 602 | val (operatorN, operator) = markup_elem "operator"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 603 | val (stringN, string) = markup_elem "string"; | 
| 59081 | 604 | val (alt_stringN, alt_string) = markup_elem "alt_string"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 605 | val (verbatimN, verbatim) = markup_elem "verbatim"; | 
| 55033 | 606 | val (cartoucheN, cartouche) = markup_elem "cartouche"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 607 | val (commentN, comment) = markup_elem "comment"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 608 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 609 | |
| 69320 | 610 | (* comments *) | 
| 611 | ||
| 612 | val (comment1N, comment1) = markup_elem "comment1"; | |
| 613 | val (comment2N, comment2) = markup_elem "comment2"; | |
| 614 | val (comment3N, comment3) = markup_elem "comment3"; | |
| 615 | ||
| 616 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 617 | (* timing *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 618 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 619 | val elapsedN = "elapsed"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 620 | val cpuN = "cpu"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 621 | val gcN = "gc"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 622 | |
| 50781 | 623 | fun timing_properties {elapsed, cpu, gc} =
 | 
| 67000 
1698e9ccef2d
more portable print_time, notably for occasional negative (!) elapsed time of theory_timing;
 wenzelm parents: 
66873diff
changeset | 624 | [(elapsedN, Value.print_time elapsed), | 
| 
1698e9ccef2d
more portable print_time, notably for occasional negative (!) elapsed time of theory_timing;
 wenzelm parents: 
66873diff
changeset | 625 | (cpuN, Value.print_time cpu), | 
| 
1698e9ccef2d
more portable print_time, notably for occasional negative (!) elapsed time of theory_timing;
 wenzelm parents: 
66873diff
changeset | 626 | (gcN, Value.print_time gc)]; | 
| 50781 | 627 | |
| 51665 | 628 | val timingN = "timing"; | 
| 629 | fun timing t = (timingN, timing_properties t); | |
| 51218 
6425a0d3b7ac
support for build passing timings from Scala to ML;
 wenzelm parents: 
51217diff
changeset | 630 | |
| 51228 | 631 | |
| 632 | (* command timing *) | |
| 633 | ||
| 634 | fun parse_command_timing_properties props = | |
| 635 | (case (Properties.get props fileN, Properties.get props offsetN, Properties.get props nameN) of | |
| 636 | (SOME file, SOME offset, SOME name) => | |
| 63806 | 637 |       SOME ({file = file, offset = Value.parse_int offset, name = name},
 | 
| 51665 | 638 | Properties.seconds props elapsedN) | 
| 51228 | 639 | | _ => NONE); | 
| 640 | ||
| 641 | ||
| 63474 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 642 | (* indentation *) | 
| 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 643 | |
| 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 644 | val (command_indentN, command_indent) = markup_int "command_indent" indentN; | 
| 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 645 | |
| 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 646 | |
| 
f66e3c3b0fb1
semantic indentation for unstructured proof scripts;
 wenzelm parents: 
63347diff
changeset | 647 | (* goals *) | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 648 | |
| 50543 | 649 | val (goalN, goal) = markup_elem "goal"; | 
| 50537 
08ce81aeeacc
more subgoal markup information, which is potentially useful to manage proof state output;
 wenzelm parents: 
50503diff
changeset | 650 | val (subgoalN, subgoal) = markup_string "subgoal" nameN; | 
| 50215 | 651 | |
| 50450 
358b6020f8b6
generalized notion of active area, where sendback is just one application;
 wenzelm parents: 
50255diff
changeset | 652 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 653 | (* command status *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 654 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 655 | val taskN = "task"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 656 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 657 | val (forkedN, forked) = markup_elem "forked"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 658 | val (joinedN, joined) = markup_elem "joined"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 659 | val (runningN, running) = markup_elem "running"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 660 | val (finishedN, finished) = markup_elem "finished"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 661 | val (failedN, failed) = markup_elem "failed"; | 
| 68871 
f5c76072db55
more explicit status for "canceled" command within theory node;
 wenzelm parents: 
68822diff
changeset | 662 | val (canceledN, canceled) = markup_elem "canceled"; | 
| 68323 | 663 | val (initializedN, initialized) = markup_elem "initialized"; | 
| 68884 
9b97d0b20d95
clarified quasi_consolidated state: ensure that exports are present for ok nodes;
 wenzelm parents: 
68871diff
changeset | 664 | val (finalizedN, finalized) = markup_elem "finalized"; | 
| 70780 
034742453594
more robust: avoid update/interrupt of long-running print_consolidation;
 wenzelm parents: 
70665diff
changeset | 665 | val (consolidatingN, consolidating) = markup_elem "consolidating"; | 
| 66379 
6392766f3c25
maintain "consolidated" status of theory nodes, which means all evals are finished (but not necessarily prints nor imports);
 wenzelm parents: 
66066diff
changeset | 666 | val (consolidatedN, consolidated) = markup_elem "consolidated"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 667 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 668 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 669 | (* messages *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 670 | |
| 50914 
fe4714886d92
identify future results more carefully, to avoid odd duplication of error messages, notably from forked goals;
 wenzelm parents: 
50845diff
changeset | 671 | val exec_idN = "exec_id"; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 672 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 673 | val initN = "init"; | 
| 61209 | 674 | val (statusN, status) = markup_elem "status"; | 
| 675 | val (resultN, result) = markup_elem "result"; | |
| 676 | val (writelnN, writeln) = markup_elem "writeln"; | |
| 677 | val (stateN, state) = markup_elem "state" | |
| 678 | val (informationN, information) = markup_elem "information"; | |
| 679 | val (tracingN, tracing) = markup_elem "tracing"; | |
| 680 | val (warningN, warning) = markup_elem "warning"; | |
| 681 | val (legacyN, legacy) = markup_elem "legacy"; | |
| 682 | val (errorN, error) = markup_elem "error"; | |
| 683 | val (systemN, system) = markup_elem "system"; | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 684 | val protocolN = "protocol"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 685 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 686 | val (reportN, report) = markup_elem "report"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 687 | val (no_reportN, no_report) = markup_elem "no_report"; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 688 | |
| 64677 
8dc24130e8fe
more uniform treatment of "bad" like other messages (with serial number);
 wenzelm parents: 
63806diff
changeset | 689 | val badN = "bad"; | 
| 
8dc24130e8fe
more uniform treatment of "bad" like other messages (with serial number);
 wenzelm parents: 
63806diff
changeset | 690 | fun bad () = (badN, serial_properties (serial ())); | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 691 | |
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 692 | val (intensifyN, intensify) = markup_elem "intensify"; | 
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 693 | |
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 694 | |
| 73835 | 695 | (* ML profiling *) | 
| 696 | ||
| 697 | val countN = "count"; | |
| 698 | ||
| 699 | val ML_profiling_entryN = "ML_profiling_entry"; | |
| 700 | fun ML_profiling_entry {name, count} =
 | |
| 701 | (ML_profiling_entryN, [(nameN, name), (countN, Value.print_int count)]); | |
| 702 | ||
| 703 | val (ML_profilingN, ML_profiling) = markup_string "ML_profiling" kindN; | |
| 704 | ||
| 705 | ||
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 706 | (* active areas *) | 
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 707 | |
| 50715 
8cfd585b9162
prefer old graph browser in Isabelle/jEdit, which still produces better layout;
 wenzelm parents: 
50683diff
changeset | 708 | val browserN = "browser" | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 709 | val graphviewN = "graphview"; | 
| 69650 | 710 | val theory_exportsN = "theory_exports"; | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 711 | |
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 712 | val sendbackN = "sendback"; | 
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 713 | val paddingN = "padding"; | 
| 52697 
6fb98a20c349
explicit padding on command boundary for "auto" generated sendback -- do not replace the corresponding goal command, but append to it;
 wenzelm parents: 
52643diff
changeset | 714 | val padding_line = (paddingN, "line"); | 
| 
6fb98a20c349
explicit padding on command boundary for "auto" generated sendback -- do not replace the corresponding goal command, but append to it;
 wenzelm parents: 
52643diff
changeset | 715 | val padding_command = (paddingN, "command"); | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 716 | |
| 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 717 | val dialogN = "dialog"; | 
| 63806 | 718 | fun dialog i result = (dialogN, [(serialN, Value.print_int i), (resultN, result)]); | 
| 50500 
c94bba7906d2
identify dialogs via official serial and maintain as result message;
 wenzelm parents: 
50499diff
changeset | 719 | |
| 63681 | 720 | val jedit_actionN = "jedit_action"; | 
| 721 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 722 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 723 | (* protocol message functions *) | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 724 | |
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 725 | val functionN = "function" | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 726 | |
| 72119 
d115d50a19c0
provide POLYSTATSDIR to keep $HOME/.polyml clean (requires Poly/ML 52881757b127, otherwise ignored);
 wenzelm parents: 
72116diff
changeset | 727 | fun ML_statistics {pid, stats_dir} =
 | 
| 
d115d50a19c0
provide POLYSTATSDIR to keep $HOME/.polyml clean (requires Poly/ML 52881757b127, otherwise ignored);
 wenzelm parents: 
72116diff
changeset | 728 |   [(functionN, "ML_statistics"), ("pid", Value.print_int pid), ("stats_dir", stats_dir)];
 | 
| 72112 
3546dd4ade74
ML statistics via external process: allows monitoring RTS while ML program sleeps;
 wenzelm parents: 
72106diff
changeset | 729 | |
| 70665 
94442fce40a5
prefer commands_accepted: fewer protocol messages;
 wenzelm parents: 
70499diff
changeset | 730 | val commands_accepted = [(functionN, "commands_accepted")]; | 
| 
94442fce40a5
prefer commands_accepted: fewer protocol messages;
 wenzelm parents: 
70499diff
changeset | 731 | |
| 52563 | 732 | val assign_update = [(functionN, "assign_update")]; | 
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 733 | val removed_versions = [(functionN, "removed_versions")]; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 734 | |
| 73419 
22f3f2117ed7
clarified signature: function_thread is determined in Isabelle/Scala, not Isabelle/ML;
 wenzelm parents: 
72861diff
changeset | 735 | fun invoke_scala name id = [(functionN, "invoke_scala"), (nameN, name), (idN, id)]; | 
| 72332 
319dd5c618a5
allow Scala function execution on separate thread: better reactivity, but potential overloading of the JVM;
 wenzelm parents: 
72156diff
changeset | 736 | |
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 737 | fun cancel_scala id = [(functionN, "cancel_scala"), (idN, id)]; | 
| 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 738 | |
| 50975 | 739 | val task_statistics = (functionN, "task_statistics"); | 
| 740 | ||
| 51216 | 741 | val command_timing = (functionN, "command_timing"); | 
| 742 | ||
| 66873 
9953ae603a23
provide theory timing information, similar to command timing but always considered relevant;
 wenzelm parents: 
66379diff
changeset | 743 | val theory_timing = (functionN, "theory_timing"); | 
| 
9953ae603a23
provide theory timing information, similar to command timing but always considered relevant;
 wenzelm parents: 
66379diff
changeset | 744 | |
| 72002 
5c4800f6b25a
more robust protocol for "Timing ..." messages, notably for pide_session=true;
 wenzelm parents: 
71912diff
changeset | 745 | val session_timing = (functionN, "session_timing"); | 
| 
5c4800f6b25a
more robust protocol for "Timing ..." messages, notably for pide_session=true;
 wenzelm parents: 
71912diff
changeset | 746 | |
| 72692 
22aeec526ffd
support for PIDE markup in batch build (inactive due to pide_reports=false);
 wenzelm parents: 
72332diff
changeset | 747 | fun loading_theory name = [("function", "loading_theory"), (nameN, name)];
 | 
| 50845 | 748 | |
| 65313 | 749 | val build_session_finished = [("function", "build_session_finished")];
 | 
| 56616 
abc2da18d08d
added protocol command "use_theories", with core functionality of batch build;
 wenzelm parents: 
56548diff
changeset | 750 | |
| 56864 | 751 | val print_operationsN = "print_operations"; | 
| 752 | val print_operations = [(functionN, print_operationsN)]; | |
| 753 | ||
| 50201 
c26369c9eda6
Isabelle-specific implementation of quasi-abstract markup elements -- back to module arrangement before d83797ef0d2d;
 wenzelm parents: 
46894diff
changeset | 754 | |
| 69788 | 755 | (* export *) | 
| 756 | ||
| 757 | val exportN = "export"; | |
| 758 | ||
| 759 | type export_args = | |
| 760 |  {id: string option,
 | |
| 761 | serial: serial, | |
| 762 | theory_name: string, | |
| 763 | name: string, | |
| 764 | executable: bool, | |
| 70499 | 765 | compress: bool, | 
| 766 | strict: bool}; | |
| 69788 | 767 | |
| 70499 | 768 | fun export ({id, serial, theory_name, name, executable, compress, strict}: export_args) =
 | 
| 69788 | 769 | [(functionN, exportN), | 
| 770 | (idN, the_default "" id), | |
| 771 | (serialN, Value.print_int serial), | |
| 772 |   ("theory_name", theory_name),
 | |
| 773 | (nameN, name), | |
| 774 |   ("executable", Value.print_bool executable),
 | |
| 70499 | 775 |   ("compress", Value.print_bool compress),
 | 
| 776 |   ("strict", Value.print_bool strict)];
 | |
| 69788 | 777 | |
| 778 | ||
| 60830 | 779 | (* debugger *) | 
| 780 | ||
| 60842 | 781 | fun debugger_state name = [(functionN, "debugger_state"), (nameN, name)]; | 
| 60834 | 782 | fun debugger_output name = [(functionN, "debugger_output"), (nameN, name)]; | 
| 60830 | 783 | |
| 784 | ||
| 55553 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 785 | (* simplifier trace *) | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 786 | |
| 57594 
037f3b251df5
regular message to refer to Simplifier Trace panel (unused);
 wenzelm parents: 
56864diff
changeset | 787 | val simp_trace_panelN = "simp_trace_panel"; | 
| 
037f3b251df5
regular message to refer to Simplifier Trace panel (unused);
 wenzelm parents: 
56864diff
changeset | 788 | |
| 55553 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 789 | val simp_trace_logN = "simp_trace_log"; | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 790 | val simp_trace_stepN = "simp_trace_step"; | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 791 | val simp_trace_recurseN = "simp_trace_recurse"; | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 792 | val simp_trace_hintN = "simp_trace_hint"; | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 793 | val simp_trace_ignoreN = "simp_trace_ignore"; | 
| 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 794 | |
| 63806 | 795 | fun simp_trace_cancel i = [(functionN, "simp_trace_cancel"), (serialN, Value.print_int i)]; | 
| 55553 
99409ccbe04a
more standard names for protocol and markup elements;
 wenzelm parents: 
55551diff
changeset | 796 | |
| 27969 | 797 | |
| 55672 
5e25cc741ab9
support for completion within the formal context;
 wenzelm parents: 
55666diff
changeset | 798 | |
| 30221 | 799 | (** print mode operations **) | 
| 23704 | 800 | |
| 69345 
6bd63c94cf62
tuned signature (see also src/Tools/Haskell/Markup.hs);
 wenzelm parents: 
69320diff
changeset | 801 | type output = Output.output * Output.output; | 
| 
6bd63c94cf62
tuned signature (see also src/Tools/Haskell/Markup.hs);
 wenzelm parents: 
69320diff
changeset | 802 | |
| 29325 | 803 | val no_output = ("", "");
 | 
| 23704 | 804 | |
| 805 | local | |
| 62933 
f14569a9ab93
proper output of markup, e.g. relevant for nested ML as used in Pure/System/bash.ML;
 wenzelm parents: 
62806diff
changeset | 806 |   val default = {output = Output_Primitives.markup_fn};
 | 
| 43684 | 807 |   val modes = Synchronized.var "Markup.modes" (Symtab.make [("", default)]);
 | 
| 23704 | 808 | in | 
| 43684 | 809 | fun add_mode name output = | 
| 46894 
e2ad717ec889
allow redefining pretty/markup modes (not output due to bootstrap issues) -- to support reloading of theory src/HOL/src/Tools/Code_Generator;
 wenzelm parents: 
45674diff
changeset | 810 | Synchronized.change modes (fn tab => | 
| 
e2ad717ec889
allow redefining pretty/markup modes (not output due to bootstrap issues) -- to support reloading of theory src/HOL/src/Tools/Code_Generator;
 wenzelm parents: 
45674diff
changeset | 811 | (if not (Symtab.defined tab name) then () | 
| 61209 | 812 |        else Output.warning ("Redefining markup mode " ^ quote name);
 | 
| 46894 
e2ad717ec889
allow redefining pretty/markup modes (not output due to bootstrap issues) -- to support reloading of theory src/HOL/src/Tools/Code_Generator;
 wenzelm parents: 
45674diff
changeset | 813 |        Symtab.update (name, {output = output}) tab));
 | 
| 23704 | 814 | fun get_mode () = | 
| 43684 | 815 | the_default default | 
| 816 | (Library.get_first (Symtab.lookup (Synchronized.value modes)) (print_mode_value ())); | |
| 23623 | 817 | end; | 
| 23704 | 818 | |
| 38474 
e498dc2eb576
uniform Markup.empty/Markup.Empty in ML and Scala;
 wenzelm parents: 
38429diff
changeset | 819 | fun output m = if is_empty m then no_output else #output (get_mode ()) m; | 
| 23704 | 820 | |
| 23719 | 821 | val enclose = output #-> Library.enclose; | 
| 822 | ||
| 25552 | 823 | fun markup m = | 
| 824 | let val (bg, en) = output m | |
| 825 | in Library.enclose (Output.escape bg) (Output.escape en) end; | |
| 826 | ||
| 59125 | 827 | val markups = fold_rev markup; | 
| 828 | ||
| 43665 | 829 | fun markup_only m = markup m ""; | 
| 830 | ||
| 55956 
94d384d621b0
reject internal term names outright, and complete consts instead;
 wenzelm parents: 
55919diff
changeset | 831 | fun markup_report "" = "" | 
| 
94d384d621b0
reject internal term names outright, and complete consts instead;
 wenzelm parents: 
55919diff
changeset | 832 | | markup_report txt = markup report txt; | 
| 
94d384d621b0
reject internal term names outright, and complete consts instead;
 wenzelm parents: 
55919diff
changeset | 833 | |
| 23704 | 834 | end; |