src/Pure/Thy/document_antiquotation.ML
author wenzelm
Wed, 11 Sep 2024 19:35:21 +0200
changeset 80855 301612847ea3
parent 80848 df85df6315af
child 80862 ab0234b9af65
permissions -rw-r--r--
further clarification of print_mode: PIDE markup depends on "isabelle_process" alone, Latex is stateless;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Thy/document_antiquotation.ML
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     3
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     4
Document antiquotations.
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     5
*)
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     6
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     7
signature DOCUMENT_ANTIQUOTATION =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     8
sig
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
     9
  val thy_output_display: bool Config.T
70121
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
    10
  val thy_output_cartouche: bool Config.T
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    11
  val thy_output_quotes: bool Config.T
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    12
  val thy_output_margin: int Config.T
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    13
  val thy_output_indent: int Config.T
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    14
  val thy_output_source: bool Config.T
70122
a0b21b4b7a4a strip cartouches from arguments of "embedded" document antiquotations, corresponding to automated update via "isabelle update -u control_cartouches" -- e.g. relevant for documents with thy_output_source (e.g. doc "isar-ref", "jedit", "system");
wenzelm
parents: 70121
diff changeset
    15
  val thy_output_source_cartouche: bool Config.T
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    16
  val thy_output_break: bool Config.T
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    17
  val thy_output_modes: string Config.T
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    18
  val trim_blanks: Proof.context -> string -> string
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    19
  val trim_lines: Proof.context -> string -> string
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    20
  val indent_lines: Proof.context -> string -> string
67474
90def2b06305 more uniform output of source / text / theory_text, with handling of formal comments etc.;
wenzelm
parents: 67472
diff changeset
    21
  val prepare_lines: Proof.context -> string -> string
70121
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
    22
  val delimit: Proof.context -> Pretty.T -> Pretty.T
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    23
  val indent: Proof.context -> Pretty.T -> Pretty.T
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    24
  val format: Proof.context -> Pretty.T -> string
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    25
  val output: Proof.context -> Pretty.T -> Output.output
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    26
  val print_antiquotations: bool -> Proof.context -> unit
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    27
  val check: Proof.context -> xstring * Position.T -> string
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    28
  val check_option: Proof.context -> xstring * Position.T -> string
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    29
  val setup: binding -> 'a context_parser ->
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    30
    ({context: Proof.context, source: Token.src, argument: 'a} -> Latex.text) -> theory -> theory
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
    31
  val setup_embedded: binding -> 'a context_parser ->
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
    32
    ({context: Proof.context, source: Token.src, argument: 'a} -> Latex.text) -> theory -> theory
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    33
  val setup_option: binding -> (string -> Proof.context -> Proof.context) -> theory -> theory
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    34
  val boolean: string -> bool
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    35
  val integer: string -> int
73780
466fae6bf22e compose Latex text as XML, output exported YXML in Isabelle/Scala;
wenzelm
parents: 73767
diff changeset
    36
  val evaluate: (Symbol_Pos.T list -> Latex.text) -> Proof.context ->
466fae6bf22e compose Latex text as XML, output exported YXML in Isabelle/Scala;
wenzelm
parents: 73767
diff changeset
    37
    Antiquote.text_antiquote -> Latex.text
73767
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
    38
  val approx_content: Proof.context -> string -> string
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    39
end;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    40
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    41
structure Document_Antiquotation: DOCUMENT_ANTIQUOTATION =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    42
struct
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    43
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    44
(* options *)
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    45
76069
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    46
val thy_output_display = Attrib.setup_option_bool (\<^system_option>\<open>thy_output_display\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    47
val thy_output_break = Attrib.setup_option_bool (\<^system_option>\<open>thy_output_break\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    48
val thy_output_cartouche = Attrib.setup_option_bool (\<^system_option>\<open>thy_output_cartouche\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    49
val thy_output_quotes = Attrib.setup_option_bool (\<^system_option>\<open>thy_output_quotes\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    50
val thy_output_margin = Attrib.setup_option_int (\<^system_option>\<open>thy_output_margin\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    51
val thy_output_indent = Attrib.setup_option_int (\<^system_option>\<open>thy_output_indent\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    52
val thy_output_source = Attrib.setup_option_bool (\<^system_option>\<open>thy_output_source\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    53
val thy_output_source_cartouche = Attrib.setup_option_bool (\<^system_option>\<open>thy_output_source_cartouche\<close>, \<^here>);
79094d7b6f22 proper antiquotations;
wenzelm
parents: 74564
diff changeset
    54
val thy_output_modes = Attrib.setup_option_string (\<^system_option>\<open>thy_output_modes\<close>, \<^here>);
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    55
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    56
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    57
(* blanks *)
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    58
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    59
fun trim_blanks ctxt =
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    60
  not (Config.get ctxt thy_output_display) ? Symbol.trim_blanks;
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    61
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    62
fun trim_lines ctxt =
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    63
  if not (Config.get ctxt thy_output_display) then
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    64
    split_lines #> map Symbol.trim_blanks #> space_implode " "
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    65
  else I;
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    66
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    67
fun indent_lines ctxt =
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    68
  if Config.get ctxt thy_output_display then
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    69
    prefix_lines (Symbol.spaces (Config.get ctxt thy_output_indent))
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    70
  else I;
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    71
67474
90def2b06305 more uniform output of source / text / theory_text, with handling of formal comments etc.;
wenzelm
parents: 67472
diff changeset
    72
fun prepare_lines ctxt = trim_lines ctxt #> indent_lines ctxt;
90def2b06305 more uniform output of source / text / theory_text, with handling of formal comments etc.;
wenzelm
parents: 67472
diff changeset
    73
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    74
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    75
(* output *)
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    76
70121
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
    77
fun delimit ctxt =
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
    78
  if Config.get ctxt thy_output_cartouche then Pretty.cartouche
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
    79
  else if Config.get ctxt thy_output_quotes then Pretty.quote
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
    80
  else I;
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    81
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    82
fun indent ctxt =
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    83
  Config.get ctxt thy_output_display ? Pretty.indent (Config.get ctxt thy_output_indent);
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    84
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    85
fun format ctxt =
80842
4d39ba5f82d6 clarified unbreakable latex output: Pretty.unformatted and (Pretty.string_of o Pretty.unbreakable) should coincide, but are produced by quite different means;
wenzelm
parents: 80841
diff changeset
    86
  let
4d39ba5f82d6 clarified unbreakable latex output: Pretty.unformatted and (Pretty.string_of o Pretty.unbreakable) should coincide, but are produced by quite different means;
wenzelm
parents: 80841
diff changeset
    87
    val breakable = Config.get ctxt thy_output_display orelse Config.get ctxt thy_output_break;
80846
9ed32b8a03a9 clarified print mode "latex": no longer impact Output/Markup/Pretty operations;
wenzelm
parents: 80842
diff changeset
    88
    val ops = Latex.output_ops (SOME (Config.get ctxt thy_output_margin));
80848
df85df6315af clarified signature: prefer explicit type Bytes.T;
wenzelm
parents: 80846
diff changeset
    89
  in not breakable ? Pretty.unbreakable #> Pretty.output ops #> Bytes.content #> Latex.escape end;
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    90
80846
9ed32b8a03a9 clarified print mode "latex": no longer impact Output/Markup/Pretty operations;
wenzelm
parents: 80842
diff changeset
    91
fun output ctxt = delimit ctxt #> indent ctxt #> format ctxt #> Latex.output_;
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    92
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
    93
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    94
(* theory data *)
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    95
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    96
structure Data = Theory_Data
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    97
(
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
    98
  type T =
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
    99
    (bool * (Token.src -> Proof.context -> Latex.text)) Name_Space.table *
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   100
      (string -> Proof.context -> Proof.context) Name_Space.table;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   101
  val empty : T =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   102
    (Name_Space.empty_table Markup.document_antiquotationN,
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   103
      Name_Space.empty_table Markup.document_antiquotation_optionN);
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   104
  fun merge ((commands1, options1), (commands2, options2)) : T =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   105
    (Name_Space.merge_tables (commands1, commands2),
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   106
      Name_Space.merge_tables (options1, options2));
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   107
);
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   108
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   109
val get_antiquotations = Data.get o Proof_Context.theory_of;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   110
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   111
fun print_antiquotations verbose ctxt =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   112
  let
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   113
    val (commands, options) = get_antiquotations ctxt;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   114
    val command_names = map #1 (Name_Space.markup_table verbose ctxt commands);
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   115
    val option_names = map #1 (Name_Space.markup_table verbose ctxt options);
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   116
  in
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   117
    [Pretty.big_list "document antiquotations:" (map Pretty.mark_str command_names),
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   118
     Pretty.big_list "document antiquotation options:" (map Pretty.mark_str option_names)]
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   119
  end |> Pretty.writeln_chunks;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   120
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   121
fun check ctxt = #1 o Name_Space.check (Context.Proof ctxt) (#1 (get_antiquotations ctxt));
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   122
fun check_option ctxt = #1 o Name_Space.check (Context.Proof ctxt) (#2 (get_antiquotations ctxt));
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   123
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   124
fun gen_setup name embedded scan body thy =
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   125
  let
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   126
    fun cmd src ctxt =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   127
      let val (x, ctxt') = Token.syntax scan src ctxt
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
   128
      in body {context = ctxt', source = src, argument = x} end;
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   129
    val entry = (name, (embedded, cmd));
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   130
  in thy |> Data.map (apfst (Name_Space.define (Context.Theory thy) true entry #> #2)) end;
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   131
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   132
fun setup name = gen_setup name false;
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   133
fun setup_embedded name = gen_setup name true;
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   134
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   135
fun setup_option name opt thy = thy
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   136
  |> Data.map (apsnd (Name_Space.define (Context.Theory thy) true (name, opt) #> #2));
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   137
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   138
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   139
(* syntax *)
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   140
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   141
local
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   142
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   143
val property =
69349
7cef9e386ffe more accurate positions for "name" (quoted string) and "embedded" (cartouche): refer to content without delimiters, which is e.g. relevant for systematic selection/renaming of scope groups;
wenzelm
parents: 68223
diff changeset
   144
  Parse.name_position -- Scan.optional (Parse.$$$ "=" |-- Parse.!!! Parse.name) "";
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   145
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   146
val properties =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   147
  Scan.optional (Parse.$$$ "[" |-- Parse.!!! (Parse.enum "," property --| Parse.$$$ "]")) [];
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   148
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   149
in
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   150
67466
wenzelm
parents: 67463
diff changeset
   151
val parse_antiq =
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   152
  Parse.!!!
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   153
    (Parse.token Parse.liberal_name -- properties -- Parse.args --| Scan.ahead Parse.eof)
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   154
  >> (fn ((name, opts), args) => (opts, name :: args));
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   155
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   156
end;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   157
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   158
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   159
(* evaluate *)
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   160
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   161
local
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   162
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   163
fun command pos (opts, src) ctxt =
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   164
  let
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   165
    val (src', (embedded, scan)) = Token.check_src ctxt (#1 o get_antiquotations) src;
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   166
    val _ =
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   167
      if null opts andalso Options.default_bool "update_control_cartouches" then
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   168
        Context_Position.reports_text ctxt
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   169
          (Antiquote.update_reports embedded pos (map Token.content_of src'))
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   170
      else ();
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   171
  in scan src' ctxt end;
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   172
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   173
fun option ((xname, pos), s) ctxt =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   174
  let
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   175
    val (_, opt) =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   176
      Name_Space.check (Context.Proof ctxt) (#2 (get_antiquotations ctxt)) (xname, pos);
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   177
  in opt s ctxt end;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   178
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   179
fun eval ctxt pos (opts, src) =
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   180
  let
68223
88dd06301dd3 override default of Isabelle_Process, notably for PIDE export of "document.tex";
wenzelm
parents: 67571
diff changeset
   181
    val preview_ctxt = fold option opts (Config.put show_markup false ctxt);
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   182
    val _ = command pos (opts, src) preview_ctxt;
67472
7ed8d4cdfb13 recovered antiquotation check without latex mode (cf. dfc93f2b01ea);
wenzelm
parents: 67466
diff changeset
   183
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   184
    val print_ctxt = Context_Position.set_visible false preview_ctxt;
80855
301612847ea3 further clarification of print_mode: PIDE markup depends on "isabelle_process" alone, Latex is stateless;
wenzelm
parents: 80848
diff changeset
   185
    val print_modes = space_explode "," (Config.get print_ctxt thy_output_modes) @ [Latex.latexN];
73780
466fae6bf22e compose Latex text as XML, output exported YXML in Isabelle/Scala;
wenzelm
parents: 73767
diff changeset
   186
  in Print_Mode.with_modes print_modes (fn () => command pos (opts, src) print_ctxt) () end;
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   187
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   188
in
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   189
73756
f9c8da253944 more ambitious default for index "is like";
wenzelm
parents: 72075
diff changeset
   190
fun read_antiq ctxt ({range = (pos, _), body, ...}: Antiquote.antiq) =
74564
0a66a61e740c clarified modules;
wenzelm
parents: 74561
diff changeset
   191
  Parse.read_antiq (Thy_Header.get_keywords' ctxt) parse_antiq (body, pos);
73756
f9c8da253944 more ambitious default for index "is like";
wenzelm
parents: 72075
diff changeset
   192
67571
f858fe5531ac more uniform treatment of formal comments within document source;
wenzelm
parents: 67474
diff changeset
   193
fun evaluate eval_text ctxt antiq =
67466
wenzelm
parents: 67463
diff changeset
   194
  (case antiq of
67571
f858fe5531ac more uniform treatment of formal comments within document source;
wenzelm
parents: 67474
diff changeset
   195
    Antiquote.Text ss => eval_text ss
67466
wenzelm
parents: 67463
diff changeset
   196
  | Antiquote.Control {name, body, ...} =>
69592
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   197
      eval ctxt Position.none
a80d8ec6c998 support for isabelle update -u control_cartouches;
wenzelm
parents: 69349
diff changeset
   198
        ([], Token.make_src name (if null body then [] else [Token.read_cartouche body]))
73756
f9c8da253944 more ambitious default for index "is like";
wenzelm
parents: 72075
diff changeset
   199
  | Antiquote.Antiq antiq => eval ctxt (#1 (#range antiq)) (read_antiq ctxt antiq));
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   200
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   201
end;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   202
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   203
73762
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   204
(* approximative content, e.g. for index entries *)
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   205
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   206
local
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   207
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   208
val strip_symbols = [Symbol.open_, Symbol.close, "'", "\"", "`"];
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   209
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   210
fun strip_symbol sym =
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   211
  if member (op =) strip_symbols sym then ""
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   212
  else
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   213
    (case Symbol.decode sym of
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   214
      Symbol.Char s => s
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   215
    | Symbol.UTF8 s => s
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   216
    | Symbol.Sym s => s
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   217
    | Symbol.Control s => s
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   218
    | _ => "");
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   219
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   220
fun strip_antiq _ (Antiquote.Text body) = map Symbol_Pos.symbol body
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   221
  | strip_antiq _ (Antiquote.Control {body, ...}) = map Symbol_Pos.symbol body
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   222
  | strip_antiq ctxt (Antiquote.Antiq antiq) =
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   223
      read_antiq ctxt antiq |> #2 |> tl
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   224
      |> maps (Symbol.explode o Token.content_of);
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   225
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   226
in
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   227
73767
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   228
fun approx_content ctxt =
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   229
  Symbol_Pos.explode0
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   230
  #> trim (Symbol.is_blank o Symbol_Pos.symbol)
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   231
  #> Antiquote.parse_comments Position.none
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   232
  #> maps (strip_antiq ctxt)
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   233
  #> map strip_symbol
b49a03bb136c tuned signature;
wenzelm
parents: 73762
diff changeset
   234
  #> implode;
73762
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   235
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   236
end;
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   237
14841c6e4d5f clarified modules;
wenzelm
parents: 73756
diff changeset
   238
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   239
(* option syntax *)
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   240
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   241
fun boolean "" = true
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   242
  | boolean "true" = true
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   243
  | boolean "false" = false
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
   244
  | boolean s = error ("Bad boolean value: " ^ Library.quote s);
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   245
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   246
fun integer s =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   247
  let
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   248
    fun int ss =
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   249
      (case Library.read_int ss of (i, []) => i
67463
a5ca98950a91 clarified access to antiquotation options;
wenzelm
parents: 67460
diff changeset
   250
      | _ => error ("Bad integer value: " ^ Library.quote s));
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   251
  in (case Symbol.explode s of "-" :: ss => ~ (int ss) | ss => int ss) end;
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   252
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   253
val _ = Theory.setup
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   254
 (setup_option \<^binding>\<open>show_types\<close> (Config.put show_types o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   255
  setup_option \<^binding>\<open>show_sorts\<close> (Config.put show_sorts o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   256
  setup_option \<^binding>\<open>show_structs\<close> (Config.put show_structs o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   257
  setup_option \<^binding>\<open>show_question_marks\<close> (Config.put show_question_marks o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   258
  setup_option \<^binding>\<open>show_abbrevs\<close> (Config.put show_abbrevs o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   259
  setup_option \<^binding>\<open>names_long\<close> (Config.put Name_Space.names_long o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   260
  setup_option \<^binding>\<open>names_short\<close> (Config.put Name_Space.names_short o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   261
  setup_option \<^binding>\<open>names_unique\<close> (Config.put Name_Space.names_unique o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   262
  setup_option \<^binding>\<open>eta_contract\<close> (Config.put Syntax_Trans.eta_contract o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   263
  setup_option \<^binding>\<open>display\<close> (Config.put thy_output_display o boolean) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   264
  setup_option \<^binding>\<open>break\<close> (Config.put thy_output_break o boolean) #>
70121
61e26527480e added document antiquotation option "cartouche";
wenzelm
parents: 69592
diff changeset
   265
  setup_option \<^binding>\<open>cartouche\<close> (Config.put thy_output_cartouche o boolean) #>
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   266
  setup_option \<^binding>\<open>quotes\<close> (Config.put thy_output_quotes o boolean) #>
67460
dfc93f2b01ea discontinued unused wrapper: print_mode is provided directly;
wenzelm
parents: 67386
diff changeset
   267
  setup_option \<^binding>\<open>mode\<close> (Config.put thy_output_modes) #>
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   268
  setup_option \<^binding>\<open>margin\<close> (Config.put thy_output_margin o integer) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   269
  setup_option \<^binding>\<open>indent\<close> (Config.put thy_output_indent o integer) #>
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   270
  setup_option \<^binding>\<open>source\<close> (Config.put thy_output_source o boolean) #>
70122
a0b21b4b7a4a strip cartouches from arguments of "embedded" document antiquotations, corresponding to automated update via "isabelle update -u control_cartouches" -- e.g. relevant for documents with thy_output_source (e.g. doc "isar-ref", "jedit", "system");
wenzelm
parents: 70121
diff changeset
   271
  setup_option \<^binding>\<open>source_cartouche\<close> (Config.put thy_output_source_cartouche o boolean) #>
67386
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   272
  setup_option \<^binding>\<open>goals_limit\<close> (Config.put Goal_Display.goals_limit o integer));
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   273
998e01d6f8fd clarified modules;
wenzelm
parents:
diff changeset
   274
end;