src/Pure/PIDE/isabelle_markup.scala
author wenzelm
Mon, 01 Oct 2012 16:37:22 +0200
changeset 49674 dbadb4d03cbc
parent 49566 66cbf8bb4693
child 50162 e06eabc421e7
permissions -rw-r--r--
report sort assignment of visible type variables;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45670
b84170538043 rearranged files;
wenzelm
parents: 45666
diff changeset
     1
/*  Title:      Pure/PIDE/isabelle_markup.scala
27958
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
     3
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 45633
diff changeset
     4
Isabelle markup elements.
27958
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
     5
*/
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
     6
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
     7
package isabelle
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
     8
27970
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
     9
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 45633
diff changeset
    10
object Isabelle_Markup
32450
375db037f4d2 misc tuning;
wenzelm
parents: 31472
diff changeset
    11
{
33088
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    12
  /* formal entities */
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    13
38887
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    14
  val BINDING = "binding"
33088
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    15
  val ENTITY = "entity"
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    16
  val DEF = "def"
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    17
  val REF = "ref"
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    18
42202
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    19
  object Entity
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    20
  {
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    21
    def unapply(markup: Markup): Option[(String, String)] =
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    22
      markup match {
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 45633
diff changeset
    23
        case Markup(ENTITY, props @ Markup.Kind(kind)) =>
42202
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    24
          props match {
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 45633
diff changeset
    25
            case Markup.Name(name) => Some(kind, name)
42202
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    26
            case _ => None
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    27
          }
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    28
        case _ => None
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    29
      }
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    30
  }
f6483ed40529 show tooltip/sub-expression for entity markup;
wenzelm
parents: 42136
diff changeset
    31
33088
757d7787b10c markup for formal entities, with "def" or "ref" occurrences;
wenzelm
parents: 32450
diff changeset
    32
27970
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    33
  /* position */
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    34
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    35
  val LINE = "line"
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    36
  val OFFSET = "offset"
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    37
  val END_OFFSET = "end_offset"
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    38
  val FILE = "file"
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    39
  val ID = "id"
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
    40
42327
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 42202
diff changeset
    41
  val DEF_LINE = "def_line"
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 42202
diff changeset
    42
  val DEF_OFFSET = "def_offset"
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 42202
diff changeset
    43
  val DEF_END_OFFSET = "def_end_offset"
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 42202
diff changeset
    44
  val DEF_FILE = "def_file"
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 42202
diff changeset
    45
  val DEF_ID = "def_id"
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 42202
diff changeset
    46
43710
7270ae921cf2 discontinued odd Position.column -- left-over from attempts at PGIP implementation;
wenzelm
parents: 43673
diff changeset
    47
  val POSITION_PROPERTIES = Set(LINE, OFFSET, END_OFFSET, FILE, ID)
43593
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    48
  val POSITION = "position"
29205
7dc7a75033ea added POSITION_PROPERTIES;
wenzelm
parents: 29195
diff changeset
    49
43593
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    50
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    51
  /* path */
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    52
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    53
  val PATH = "path"
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    54
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    55
  object Path
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    56
  {
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    57
    def unapply(markup: Markup): Option[String] =
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    58
      markup match {
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 45633
diff changeset
    59
        case Markup(PATH, Markup.Name(name)) => Some(name)
43593
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    60
        case _ => None
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    61
      }
11140987d415 print Path.T with some markup;
wenzelm
parents: 43564
diff changeset
    62
  }
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    63
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    64
36683
41a1210519fd basic support for symbolic pretty printing;
wenzelm
parents: 34242
diff changeset
    65
  /* pretty printing */
41a1210519fd basic support for symbolic pretty printing;
wenzelm
parents: 34242
diff changeset
    66
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 43748
diff changeset
    67
  val Indent = new Properties.Int("indent")
36683
41a1210519fd basic support for symbolic pretty printing;
wenzelm
parents: 34242
diff changeset
    68
  val BLOCK = "block"
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 43748
diff changeset
    69
  val Width = new Properties.Int("width")
36683
41a1210519fd basic support for symbolic pretty printing;
wenzelm
parents: 34242
diff changeset
    70
  val BREAK = "break"
41a1210519fd basic support for symbolic pretty printing;
wenzelm
parents: 34242
diff changeset
    71
49473
ca7e2c21b104 tuned rendering;
wenzelm
parents: 49418
diff changeset
    72
  val SEPARATOR = "separator"
ca7e2c21b104 tuned rendering;
wenzelm
parents: 49418
diff changeset
    73
36683
41a1210519fd basic support for symbolic pretty printing;
wenzelm
parents: 34242
diff changeset
    74
33985
1d33e85a3fa9 added markup for hidden text;
wenzelm
parents: 33088
diff changeset
    75
  /* hidden text */
1d33e85a3fa9 added markup for hidden text;
wenzelm
parents: 33088
diff changeset
    76
1d33e85a3fa9 added markup for hidden text;
wenzelm
parents: 33088
diff changeset
    77
  val HIDDEN = "hidden"
1d33e85a3fa9 added markup for hidden text;
wenzelm
parents: 33088
diff changeset
    78
1d33e85a3fa9 added markup for hidden text;
wenzelm
parents: 33088
diff changeset
    79
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    80
  /* logical entities */
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    81
43551
07a9cbf2376f clarified Markup.CLASS vs. HTML.CLASS;
wenzelm
parents: 43432
diff changeset
    82
  val CLASS = "class"
49321
a48f9bbbe720 avoid spaces in markup names, which might cause problems in boundary situations (e.g. HTML class);
wenzelm
parents: 49036
diff changeset
    83
  val TYPE_NAME = "type_name"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    84
  val FIXED = "fixed"
43552
156c822f181a entity markup for "type", "constant";
wenzelm
parents: 43551
diff changeset
    85
  val CONSTANT = "constant"
156c822f181a entity markup for "type", "constant";
wenzelm
parents: 43551
diff changeset
    86
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    87
  val DYNAMIC_FACT = "dynamic_fact"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    88
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    89
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    90
  /* inner syntax */
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    91
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    92
  val TFREE = "tfree"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    93
  val TVAR = "tvar"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    94
  val FREE = "free"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    95
  val SKOLEM = "skolem"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    96
  val BOUND = "bound"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    97
  val VAR = "var"
45702
7df60d1aa988 updated markup conforming to ML side;
wenzelm
parents: 45674
diff changeset
    98
  val NUMERAL = "numeral"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
    99
  val LITERAL = "literal"
43432
224006e5ac46 inner literal/delimiter corresponds to outer keyword/operator;
wenzelm
parents: 43386
diff changeset
   100
  val DELIMITER = "delimiter"
43386
4e78dd88c64f more foreground markup, using actual CSS color names;
wenzelm
parents: 42492
diff changeset
   101
  val INNER_STRING = "inner_string"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   102
  val INNER_COMMENT = "inner_comment"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   103
39168
e3ac771235f7 report token range after inner parse error -- often provides important clues about misunderstanding concerning lexical phase;
wenzelm
parents: 38887
diff changeset
   104
  val TOKEN_RANGE = "token_range"
e3ac771235f7 report token range after inner parse error -- often provides important clues about misunderstanding concerning lexical phase;
wenzelm
parents: 38887
diff changeset
   105
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   106
  val SORT = "sort"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   107
  val TYP = "typ"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   108
  val TERM = "term"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   109
  val PROP = "prop"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   110
49674
dbadb4d03cbc report sort assignment of visible type variables;
wenzelm
parents: 49566
diff changeset
   111
  val SORTING = "sorting"
45445
41e641a870de pass term positions into check phase, where resulting types are reported accordingly, and eventually shown as tooltips;
wenzelm
parents: 44706
diff changeset
   112
  val TYPING = "typing"
41e641a870de pass term positions into check phase, where resulting types are reported accordingly, and eventually shown as tooltips;
wenzelm
parents: 44706
diff changeset
   113
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   114
  val ATTRIBUTE = "attribute"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   115
  val METHOD = "method"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   116
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   117
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   118
  /* embedded source text */
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   119
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   120
  val ML_SOURCE = "ML_source"
49321
a48f9bbbe720 avoid spaces in markup names, which might cause problems in boundary situations (e.g. HTML class);
wenzelm
parents: 49036
diff changeset
   121
  val DOCUMENT_SOURCE = "document_source"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   122
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   123
  val ANTIQ = "antiq"
49321
a48f9bbbe720 avoid spaces in markup names, which might cause problems in boundary situations (e.g. HTML class);
wenzelm
parents: 49036
diff changeset
   124
  val ML_ANTIQUOTATION = "ML_antiquotation"
a48f9bbbe720 avoid spaces in markup names, which might cause problems in boundary situations (e.g. HTML class);
wenzelm
parents: 49036
diff changeset
   125
  val DOCUMENT_ANTIQUOTATION = "document_antiquotation"
a48f9bbbe720 avoid spaces in markup names, which might cause problems in boundary situations (e.g. HTML class);
wenzelm
parents: 49036
diff changeset
   126
  val DOCUMENT_ANTIQUOTATION_OPTION = "document_antiquotation_option"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   127
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   128
30615
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   129
  /* ML syntax */
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   130
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   131
  val ML_KEYWORD = "ML_keyword"
37195
e87d305a4490 separate markup for ML delimiters;
wenzelm
parents: 37194
diff changeset
   132
  val ML_DELIMITER = "ML_delimiter"
30615
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   133
  val ML_TVAR = "ML_tvar"
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   134
  val ML_NUMERAL = "ML_numeral"
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   135
  val ML_CHAR = "ML_char"
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   136
  val ML_STRING = "ML_string"
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   137
  val ML_COMMENT = "ML_comment"
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   138
30702
274626e2b2dd more markup elements for ML programs;
wenzelm
parents: 30615
diff changeset
   139
  val ML_DEF = "ML_def"
31472
d7929d74acb4 added markup ML_open, ML_struct;
wenzelm
parents: 31384
diff changeset
   140
  val ML_OPEN = "ML_open"
d7929d74acb4 added markup ML_open, ML_struct;
wenzelm
parents: 31384
diff changeset
   141
  val ML_STRUCT = "ML_struct"
30702
274626e2b2dd more markup elements for ML programs;
wenzelm
parents: 30615
diff changeset
   142
  val ML_TYPING = "ML_typing"
274626e2b2dd more markup elements for ML programs;
wenzelm
parents: 30615
diff changeset
   143
30615
f1275196df16 added ML syntax markup;
wenzelm
parents: 29522
diff changeset
   144
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   145
  /* outer syntax */
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   146
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   147
  val KEYWORD = "keyword"
37194
825456e5db30 less pschedelic token markup;
wenzelm
parents: 37186
diff changeset
   148
  val OPERATOR = "operator"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   149
  val COMMAND = "command"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   150
  val STRING = "string"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   151
  val ALTSTRING = "altstring"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   152
  val VERBATIM = "verbatim"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   153
  val COMMENT = "comment"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   154
  val CONTROL = "control"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   155
49554
7b7bd2d7661d more explicit keyword1/keyword2 markup -- avoid potential conflict with input token markup produced by Token_Marker;
wenzelm
parents: 49473
diff changeset
   156
  val KEYWORD1 = "keyword1"
7b7bd2d7661d more explicit keyword1/keyword2 markup -- avoid potential conflict with input token markup produced by Token_Marker;
wenzelm
parents: 49473
diff changeset
   157
  val KEYWORD2 = "keyword2"
7b7bd2d7661d more explicit keyword1/keyword2 markup -- avoid potential conflict with input token markup produced by Token_Marker;
wenzelm
parents: 49473
diff changeset
   158
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   159
45674
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   160
  /* timing */
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   161
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   162
  val TIMING = "timing"
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   163
  val ELAPSED = "elapsed"
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   164
  val CPU = "cpu"
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   165
  val GC = "gc"
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   166
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   167
  object Timing
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   168
  {
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   169
    def apply(timing: isabelle.Timing): Markup =
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   170
      Markup(TIMING, List(
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   171
        (ELAPSED, Properties.Value.Double(timing.elapsed.seconds)),
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   172
        (CPU, Properties.Value.Double(timing.cpu.seconds)),
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   173
        (GC, Properties.Value.Double(timing.gc.seconds))))
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   174
    def unapply(markup: Markup): Option[isabelle.Timing] =
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   175
      markup match {
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   176
        case Markup(TIMING, List(
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   177
          (ELAPSED, Properties.Value.Double(elapsed)),
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   178
          (CPU, Properties.Value.Double(cpu)),
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   179
          (GC, Properties.Value.Double(gc)))) =>
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   180
            Some(new isabelle.Timing(Time.seconds(elapsed), Time.seconds(cpu), Time.seconds(gc)))
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   181
        case _ => None
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   182
      }
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   183
  }
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   184
eb65c9d17e2f clarified Time vs. Timing;
wenzelm
parents: 45670
diff changeset
   185
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   186
  /* toplevel */
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   187
38721
ca8b14fa0d0d added some proof state markup, notably number of subgoals (e.g. for indentation);
wenzelm
parents: 38474
diff changeset
   188
  val SUBGOALS = "subgoals"
ca8b14fa0d0d added some proof state markup, notably number of subgoals (e.g. for indentation);
wenzelm
parents: 38474
diff changeset
   189
  val PROOF_STATE = "proof_state"
ca8b14fa0d0d added some proof state markup, notably number of subgoals (e.g. for indentation);
wenzelm
parents: 38474
diff changeset
   190
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   191
  val STATE = "state"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   192
  val SUBGOAL = "subgoal"
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   193
  val SENDBACK = "sendback"
49358
0fa351b1bd14 clarified markup names;
wenzelm
parents: 49321
diff changeset
   194
  val INTENSIFY = "intensify"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   195
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   196
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   197
  /* command status */
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   198
29417
779ff1187327 added running task markup;
wenzelm
parents: 29205
diff changeset
   199
  val TASK = "task"
779ff1187327 added running task markup;
wenzelm
parents: 29205
diff changeset
   200
47395
e6261a493f04 added static command status markup, to emphasize accepted but unassigned/unparsed commands (notably in overview panel);
wenzelm
parents: 46910
diff changeset
   201
  val ACCEPTED = "accepted"
37186
349e9223c685 explicit markup for forked goals, as indicated by Goal.fork;
wenzelm
parents: 37121
diff changeset
   202
  val FORKED = "forked"
349e9223c685 explicit markup for forked goals, as indicated by Goal.fork;
wenzelm
parents: 37121
diff changeset
   203
  val JOINED = "joined"
49036
4680c4046814 further refinement of command status, to accomodate forked proofs;
wenzelm
parents: 49009
diff changeset
   204
  val RUNNING = "running"
4680c4046814 further refinement of command status, to accomodate forked proofs;
wenzelm
parents: 49009
diff changeset
   205
  val FINISHED = "finished"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   206
  val FAILED = "failed"
29488
8fc3aeece219 replaced command_state by edits/edit;
wenzelm
parents: 29482
diff changeset
   207
8fc3aeece219 replaced command_state by edits/edit;
wenzelm
parents: 29482
diff changeset
   208
8fc3aeece219 replaced command_state by edits/edit;
wenzelm
parents: 29482
diff changeset
   209
  /* interactive documents */
8fc3aeece219 replaced command_state by edits/edit;
wenzelm
parents: 29482
diff changeset
   210
38414
49f1f657adc2 more basic Markup.parse_int/print_int (using signed_string_of_int) (ML);
wenzelm
parents: 38355
diff changeset
   211
  val VERSION = "version"
49f1f657adc2 more basic Markup.parse_int/print_int (using signed_string_of_int) (ML);
wenzelm
parents: 38355
diff changeset
   212
  val ASSIGN = "assign"
29184
85889d58b5da more markup elements;
wenzelm
parents: 29140
diff changeset
   213
27970
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
   214
43721
fad8634cee62 echo prover input via raw_messages, for improved protocol tracing;
wenzelm
parents: 43710
diff changeset
   215
  /* prover process */
fad8634cee62 echo prover input via raw_messages, for improved protocol tracing;
wenzelm
parents: 43710
diff changeset
   216
fad8634cee62 echo prover input via raw_messages, for improved protocol tracing;
wenzelm
parents: 43710
diff changeset
   217
  val PROVER_COMMAND = "prover_command"
fad8634cee62 echo prover input via raw_messages, for improved protocol tracing;
wenzelm
parents: 43710
diff changeset
   218
  val PROVER_ARG = "prover_arg"
fad8634cee62 echo prover input via raw_messages, for improved protocol tracing;
wenzelm
parents: 43710
diff changeset
   219
fad8634cee62 echo prover input via raw_messages, for improved protocol tracing;
wenzelm
parents: 43710
diff changeset
   220
27970
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
   221
  /* messages */
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
   222
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 43748
diff changeset
   223
  val Serial = new Properties.Long("serial")
27970
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
   224
29195
ea51797fa416 more markup elements;
wenzelm
parents: 29185
diff changeset
   225
  val MESSAGE = "message"
29522
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   226
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   227
  val INIT = "init"
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   228
  val STATUS = "status"
39525
72e949a0425b simplified Isabelle_Process message kinds;
wenzelm
parents: 39513
diff changeset
   229
  val REPORT = "report"
29522
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   230
  val WRITELN = "writeln"
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   231
  val TRACING = "tracing"
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   232
  val WARNING = "warning"
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   233
  val ERROR = "error"
46774
38f113b052b1 clarified terminology of raw protocol messages;
wenzelm
parents: 46649
diff changeset
   234
  val PROTOCOL = "protocol"
29522
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   235
  val SYSTEM = "system"
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   236
  val STDOUT = "stdout"
45633
2cb7e34f6096 retain stderr and include it in syslog, which is buffered and thus increases the chance that users see remains from crashes etc.;
wenzelm
parents: 45445
diff changeset
   237
  val STDERR = "stderr"
29522
793766d4c1b5 moved message markup into Scala layer -- reduced redundancy;
wenzelm
parents: 29488
diff changeset
   238
  val EXIT = "exit"
29195
ea51797fa416 more markup elements;
wenzelm
parents: 29185
diff changeset
   239
49418
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   240
  val WRITELN_MESSAGE = "writeln_message"
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   241
  val TRACING_MESSAGE = "tracing_message"
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   242
  val WARNING_MESSAGE = "warning_message"
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   243
  val ERROR_MESSAGE = "error_message"
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   244
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   245
  val message: String => String =
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   246
    Map(WRITELN -> WRITELN_MESSAGE, TRACING -> TRACING_MESSAGE,
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   247
        WARNING -> WARNING_MESSAGE, ERROR -> ERROR_MESSAGE)
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   248
      .withDefault((name: String) => name + "_message")
c451856129cd more explicit message markup and rendering;
wenzelm
parents: 49358
diff changeset
   249
48016
edbc8e8accd9 more explicit treatment of return code vs. session phase;
wenzelm
parents: 47395
diff changeset
   250
  val Return_Code = new Properties.Int("return_code")
edbc8e8accd9 more explicit treatment of return code vs. session phase;
wenzelm
parents: 47395
diff changeset
   251
44549
5e5e6ad3922c explicit markup for legacy warnings;
wenzelm
parents: 44476
diff changeset
   252
  val LEGACY = "legacy"
5e5e6ad3922c explicit markup for legacy warnings;
wenzelm
parents: 44476
diff changeset
   253
39439
1c294d150ded eliminated markup "location" in favour of more explicit "no_report", which is actually deleted from messages;
wenzelm
parents: 39171
diff changeset
   254
  val NO_REPORT = "no_report"
1c294d150ded eliminated markup "location" in favour of more explicit "no_report", which is actually deleted from messages;
wenzelm
parents: 39171
diff changeset
   255
39171
525a13b9ac74 highlight bad range of nested error (here from inner parsing);
wenzelm
parents: 39168
diff changeset
   256
  val BAD = "bad"
525a13b9ac74 highlight bad range of nested error (here from inner parsing);
wenzelm
parents: 39168
diff changeset
   257
49566
66cbf8bb4693 basic integration of graphview into document model;
wenzelm
parents: 49554
diff changeset
   258
  val GRAPHVIEW = "graphview"
66cbf8bb4693 basic integration of graphview into document model;
wenzelm
parents: 49554
diff changeset
   259
27970
3dd5fbdf61c4 added position, messages;
wenzelm
parents: 27958
diff changeset
   260
46774
38f113b052b1 clarified terminology of raw protocol messages;
wenzelm
parents: 46649
diff changeset
   261
  /* protocol message functions */
43748
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   262
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   263
  val FUNCTION = "function"
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 43748
diff changeset
   264
  val Function = new Properties.String(FUNCTION)
43748
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   265
44661
383c9d758a56 raw message function "assign_execs" avoids full overhead of decoding and caching message body;
wenzelm
parents: 44549
diff changeset
   266
  val Assign_Execs: Properties.T = List((FUNCTION, "assign_execs"))
44676
7de87f1ae965 Document.removed_versions on Scala side;
wenzelm
parents: 44661
diff changeset
   267
  val Removed_Versions: Properties.T = List((FUNCTION, "removed_versions"))
44661
383c9d758a56 raw message function "assign_execs" avoids full overhead of decoding and caching message body;
wenzelm
parents: 44549
diff changeset
   268
43748
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   269
  object Invoke_Scala
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   270
  {
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 43748
diff changeset
   271
    def unapply(props: Properties.T): Option[(String, String)] =
43748
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   272
      props match {
46122
1e9ec1a44dfc prefer raw_message for protocol implementation;
wenzelm
parents: 46121
diff changeset
   273
        case List((FUNCTION, "invoke_scala"), (Markup.NAME, name), (ID, id)) => Some((name, id))
43748
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   274
        case _ => None
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   275
      }
c70bd78ec83c JVM method invocation service via Scala layer;
wenzelm
parents: 43746
diff changeset
   276
  }
44298
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   277
  object Cancel_Scala
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   278
  {
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   279
    def unapply(props: Properties.T): Option[String] =
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   280
      props match {
46122
1e9ec1a44dfc prefer raw_message for protocol implementation;
wenzelm
parents: 46121
diff changeset
   281
        case List((FUNCTION, "cancel_scala"), (ID, id)) => Some(id)
44298
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   282
        case _ => None
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   283
      }
b8f8488704e2 Future.promise: explicit abort operation (like uninterruptible future job);
wenzelm
parents: 43780
diff changeset
   284
  }
27958
292d78c906b1 Common markup elements.
wenzelm
parents:
diff changeset
   285
}
38230
ed147003de4b simplified type XML.Tree: embed Markup directly, avoid slightly odd triple;
wenzelm
parents: 37195
diff changeset
   286