src/Pure/PIDE/rendering.scala
author wenzelm
Wed, 08 Mar 2017 10:29:40 +0100
changeset 65150 fa299b4e50c3
parent 65149 9dccbebf4511
child 65176 908d8be90533
permissions -rw-r--r--
clarified rendering;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64622
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/PIDE/rendering.scala
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     3
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     4
Isabelle-specific implementation of quasi-abstract rendering and
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     5
markup interpretation.
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     6
*/
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     7
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     8
package isabelle
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
     9
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
    10
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
    11
object Rendering
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
    12
{
65101
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    13
  /* color */
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    14
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    15
  object Color extends Enumeration
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    16
  {
65104
66b19d05dcee decorations for background and foreground colors;
wenzelm
parents: 65101
diff changeset
    17
    // background
65101
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    18
    val unprocessed1 = Value("unprocessed1")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    19
    val running1 = Value("running1")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    20
    val bad = Value("bad")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    21
    val intensify = Value("intensify")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    22
    val entity = Value("entity")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    23
    val active = Value("active")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    24
    val active_result = Value("active_result")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    25
    val markdown_item1 = Value("markdown_item1")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    26
    val markdown_item2 = Value("markdown_item2")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    27
    val markdown_item3 = Value("markdown_item3")
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    28
    val markdown_item4 = Value("markdown_item4")
65143
wenzelm
parents: 65139
diff changeset
    29
    val background_colors = values
65104
66b19d05dcee decorations for background and foreground colors;
wenzelm
parents: 65101
diff changeset
    30
66b19d05dcee decorations for background and foreground colors;
wenzelm
parents: 65101
diff changeset
    31
    // foreground
66b19d05dcee decorations for background and foreground colors;
wenzelm
parents: 65101
diff changeset
    32
    val quoted = Value("quoted")
66b19d05dcee decorations for background and foreground colors;
wenzelm
parents: 65101
diff changeset
    33
    val antiquoted = Value("antiquoted")
65143
wenzelm
parents: 65139
diff changeset
    34
    val foreground_colors = values -- background_colors
65121
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
    35
65124
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    36
    // message underline
65121
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
    37
    val writeln = Value("writeln")
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
    38
    val information = Value("information")
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
    39
    val warning = Value("warning")
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
    40
    val legacy = Value("legacy")
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
    41
    val error = Value("error")
65143
wenzelm
parents: 65139
diff changeset
    42
    val message_underline_colors = values -- background_colors -- foreground_colors
65124
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    43
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    44
    // message background
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    45
    val writeln_message = Value("writeln_message")
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    46
    val information_message = Value("information_message")
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    47
    val tracing_message = Value("tracing_message")
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    48
    val warning_message = Value("warning_message")
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    49
    val legacy_message = Value("legacy_message")
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
    50
    val error_message = Value("error_message")
65143
wenzelm
parents: 65139
diff changeset
    51
    val message_background_colors =
wenzelm
parents: 65139
diff changeset
    52
      values -- background_colors -- foreground_colors -- message_underline_colors
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    53
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    54
    // text
65145
wenzelm
parents: 65144
diff changeset
    55
    val main = Value("main")
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    56
    val keyword1 = Value("keyword1")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    57
    val keyword2 = Value("keyword2")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    58
    val keyword3 = Value("keyword3")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    59
    val quasi_keyword = Value("quasi_keyword")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    60
    val improper = Value("improper")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    61
    val operator = Value("operator")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    62
    val tfree = Value("tfree")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    63
    val tvar = Value("tvar")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    64
    val free = Value("free")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    65
    val skolem = Value("skolem")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    66
    val bound = Value("bound")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    67
    val var_ = Value("var")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    68
    val inner_numeral = Value("inner_numeral")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    69
    val inner_quoted = Value("inner_quoted")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    70
    val inner_cartouche = Value("inner_cartouche")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    71
    val inner_comment = Value("inner_comment")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    72
    val dynamic = Value("dynamic")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    73
    val class_parameter = Value("class_parameter")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    74
    val antiquote = Value("antiquote")
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    75
    val text_colors =
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    76
      values -- background_colors -- foreground_colors -- message_underline_colors --
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
    77
      message_background_colors
65101
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    78
  }
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    79
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
    80
64676
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    81
  /* message priorities */
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    82
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    83
  val state_pri = 1
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    84
  val writeln_pri = 2
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    85
  val information_pri = 3
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    86
  val tracing_pri = 4
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    87
  val warning_pri = 5
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    88
  val legacy_pri = 6
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    89
  val error_pri = 7
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    90
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    91
  val message_pri = Map(
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    92
    Markup.STATE -> state_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    93
    Markup.STATE_MESSAGE -> state_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    94
    Markup.WRITELN -> writeln_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    95
    Markup.WRITELN_MESSAGE -> writeln_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    96
    Markup.INFORMATION -> information_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    97
    Markup.INFORMATION_MESSAGE -> information_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    98
    Markup.TRACING -> tracing_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
    99
    Markup.TRACING_MESSAGE -> tracing_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   100
    Markup.WARNING -> warning_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   101
    Markup.WARNING_MESSAGE -> warning_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   102
    Markup.LEGACY -> legacy_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   103
    Markup.LEGACY_MESSAGE -> legacy_pri,
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   104
    Markup.ERROR -> error_pri,
65133
41f80c6978bc more robust;
wenzelm
parents: 65129
diff changeset
   105
    Markup.ERROR_MESSAGE -> error_pri
41f80c6978bc more robust;
wenzelm
parents: 65129
diff changeset
   106
  ).withDefaultValue(0)
64676
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   107
65121
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   108
  val message_underline_color = Map(
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   109
    writeln_pri -> Color.writeln,
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   110
    information_pri -> Color.information,
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   111
    warning_pri -> Color.warning,
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   112
    legacy_pri -> Color.legacy,
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   113
    error_pri -> Color.error)
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   114
65124
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   115
  val message_background_color = Map(
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   116
    writeln_pri -> Color.writeln_message,
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   117
    information_pri -> Color.information_message,
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   118
    tracing_pri -> Color.tracing_message,
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   119
    warning_pri -> Color.warning_message,
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   120
    legacy_pri -> Color.legacy_message,
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   121
    error_pri -> Color.error_message)
759c64c39a6f more generic colors;
wenzelm
parents: 65121
diff changeset
   122
64676
fd2df1ea3bb4 clarified modules;
wenzelm
parents: 64660
diff changeset
   123
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   124
  /* text color */
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   125
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   126
  val text_color = Map(
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   127
    Markup.KEYWORD1 -> Color.keyword1,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   128
    Markup.KEYWORD2 -> Color.keyword2,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   129
    Markup.KEYWORD3 -> Color.keyword3,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   130
    Markup.QUASI_KEYWORD -> Color.quasi_keyword,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   131
    Markup.IMPROPER -> Color.improper,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   132
    Markup.OPERATOR -> Color.operator,
65145
wenzelm
parents: 65144
diff changeset
   133
    Markup.STRING -> Color.main,
wenzelm
parents: 65144
diff changeset
   134
    Markup.ALT_STRING -> Color.main,
wenzelm
parents: 65144
diff changeset
   135
    Markup.VERBATIM -> Color.main,
wenzelm
parents: 65144
diff changeset
   136
    Markup.CARTOUCHE -> Color.main,
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   137
    Markup.LITERAL -> Color.keyword1,
65145
wenzelm
parents: 65144
diff changeset
   138
    Markup.DELIMITER -> Color.main,
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   139
    Markup.TFREE -> Color.tfree,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   140
    Markup.TVAR -> Color.tvar,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   141
    Markup.FREE -> Color.free,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   142
    Markup.SKOLEM -> Color.skolem,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   143
    Markup.BOUND -> Color.bound,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   144
    Markup.VAR -> Color.var_,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   145
    Markup.INNER_STRING -> Color.inner_quoted,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   146
    Markup.INNER_CARTOUCHE -> Color.inner_cartouche,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   147
    Markup.INNER_COMMENT -> Color.inner_comment,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   148
    Markup.DYNAMIC_FACT -> Color.dynamic,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   149
    Markup.CLASS_PARAMETER -> Color.class_parameter,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   150
    Markup.ANTIQUOTE -> Color.antiquote,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   151
    Markup.ML_KEYWORD1 -> Color.keyword1,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   152
    Markup.ML_KEYWORD2 -> Color.keyword2,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   153
    Markup.ML_KEYWORD3 -> Color.keyword3,
65145
wenzelm
parents: 65144
diff changeset
   154
    Markup.ML_DELIMITER -> Color.main,
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   155
    Markup.ML_NUMERAL -> Color.inner_numeral,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   156
    Markup.ML_CHAR -> Color.inner_quoted,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   157
    Markup.ML_STRING -> Color.inner_quoted,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   158
    Markup.ML_COMMENT -> Color.inner_comment,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   159
    Markup.SML_STRING -> Color.inner_quoted,
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   160
    Markup.SML_COMMENT -> Color.inner_comment)
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   161
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   162
65149
wenzelm
parents: 65145
diff changeset
   163
  /* tooltips */
65101
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   164
65149
wenzelm
parents: 65145
diff changeset
   165
  val tooltip_descriptions =
64622
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   166
    Map(
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   167
      Markup.CITATION -> "citation",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   168
      Markup.TOKEN_RANGE -> "inner syntax token",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   169
      Markup.FREE -> "free variable",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   170
      Markup.SKOLEM -> "skolem variable",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   171
      Markup.BOUND -> "bound variable",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   172
      Markup.VAR -> "schematic variable",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   173
      Markup.TFREE -> "free type variable",
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   174
      Markup.TVAR -> "schematic type variable")
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   175
65149
wenzelm
parents: 65145
diff changeset
   176
wenzelm
parents: 65145
diff changeset
   177
  /* markup elements */
wenzelm
parents: 65145
diff changeset
   178
wenzelm
parents: 65145
diff changeset
   179
  val active_elements =
wenzelm
parents: 65145
diff changeset
   180
    Markup.Elements(Markup.DIALOG, Markup.BROWSER, Markup.GRAPHVIEW,
wenzelm
parents: 65145
diff changeset
   181
      Markup.SENDBACK, Markup.JEDIT_ACTION, Markup.SIMP_TRACE_PANEL)
wenzelm
parents: 65145
diff changeset
   182
wenzelm
parents: 65145
diff changeset
   183
  val background_elements =
wenzelm
parents: 65145
diff changeset
   184
    Protocol.proper_status_elements + Markup.WRITELN_MESSAGE +
wenzelm
parents: 65145
diff changeset
   185
      Markup.STATE_MESSAGE + Markup.INFORMATION_MESSAGE +
wenzelm
parents: 65145
diff changeset
   186
      Markup.TRACING_MESSAGE + Markup.WARNING_MESSAGE +
wenzelm
parents: 65145
diff changeset
   187
      Markup.LEGACY_MESSAGE + Markup.ERROR_MESSAGE +
wenzelm
parents: 65145
diff changeset
   188
      Markup.BAD + Markup.INTENSIFY + Markup.ENTITY +
wenzelm
parents: 65145
diff changeset
   189
      Markup.Markdown_Item.name ++ active_elements
wenzelm
parents: 65145
diff changeset
   190
wenzelm
parents: 65145
diff changeset
   191
  val foreground_elements =
wenzelm
parents: 65145
diff changeset
   192
    Markup.Elements(Markup.STRING, Markup.ALT_STRING, Markup.VERBATIM,
wenzelm
parents: 65145
diff changeset
   193
      Markup.CARTOUCHE, Markup.ANTIQUOTED)
wenzelm
parents: 65145
diff changeset
   194
wenzelm
parents: 65145
diff changeset
   195
  val semantic_completion_elements =
wenzelm
parents: 65145
diff changeset
   196
    Markup.Elements(Markup.COMPLETION, Markup.NO_COMPLETION)
wenzelm
parents: 65145
diff changeset
   197
65129
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   198
  val tooltip_elements =
64622
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   199
    Markup.Elements(Markup.LANGUAGE, Markup.EXPRESSION, Markup.TIMING, Markup.ENTITY,
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   200
      Markup.SORTING, Markup.TYPING, Markup.CLASS_PARAMETER, Markup.ML_TYPING,
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   201
      Markup.ML_BREAKPOINT, Markup.PATH, Markup.DOC, Markup.URL, Markup.MARKDOWN_PARAGRAPH,
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   202
      Markup.Markdown_List.name) ++ Markup.Elements(tooltip_descriptions.keySet)
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   203
65129
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   204
  val tooltip_message_elements =
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   205
    Markup.Elements(Markup.WRITELN, Markup.INFORMATION, Markup.WARNING, Markup.LEGACY, Markup.ERROR,
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   206
      Markup.BAD)
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   207
64767
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   208
  val caret_focus_elements = Markup.Elements(Markup.ENTITY)
65144
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   209
b5782e996651 more generic colors;
wenzelm
parents: 65143
diff changeset
   210
  val text_color_elements = Markup.Elements(text_color.keySet)
64622
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   211
}
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   212
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   213
abstract class Rendering(
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   214
  val snapshot: Document.Snapshot,
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   215
  val options: Options,
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   216
  val resources: Resources)
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   217
{
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   218
  override def toString: String = "Rendering(" + snapshot.toString + ")"
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   219
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   220
64877
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   221
  /* completion */
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   222
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   223
  def semantic_completion(completed_range: Option[Text.Range], range: Text.Range)
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   224
      : Option[Text.Info[Completion.Semantic]] =
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   225
    if (snapshot.is_outdated) None
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   226
    else {
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   227
      snapshot.select(range, Rendering.semantic_completion_elements, _ =>
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   228
        {
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   229
          case Completion.Semantic.Info(info) =>
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   230
            completed_range match {
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   231
              case Some(range0) if range0.contains(info.range) && range0 != info.range => None
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   232
              case _ => Some(info)
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   233
            }
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   234
          case _ => None
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   235
        }).headOption.map(_.info)
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   236
    }
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   237
31e9920a0dc1 support for semantic completion;
wenzelm
parents: 64767
diff changeset
   238
65139
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   239
  /* spell checker */
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   240
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   241
  private lazy val spell_checker_elements =
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   242
    Markup.Elements(space_explode(',', options.string("spell_checker_elements")): _*)
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   243
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   244
  def spell_checker_ranges(range: Text.Range): List[Text.Range] =
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   245
    snapshot.select(range, spell_checker_elements, _ => _ => Some(())).map(_.range)
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   246
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   247
  def spell_checker_point(range: Text.Range): Option[Text.Range] =
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   248
    snapshot.select(range, spell_checker_elements, _ =>
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   249
      {
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   250
        case info => Some(snapshot.convert(info.range))
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   251
      }).headOption.map(_.info)
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   252
0a2c0712e432 clarified modules: spell-checker in Pure;
wenzelm
parents: 65133
diff changeset
   253
65101
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   254
  /* text background */
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   255
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   256
  def background(range: Text.Range, focus: Set[Long]): List[Text.Info[Rendering.Color.Value]] =
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   257
  {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   258
    for {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   259
      Text.Info(r, result) <-
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   260
        snapshot.cumulate[(List[Markup], Option[Rendering.Color.Value])](
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   261
          range, (List(Markup.Empty), None), Rendering.background_elements,
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   262
          command_states =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   263
            {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   264
              case (((markups, color), Text.Info(_, XML.Elem(markup, _))))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   265
              if markups.nonEmpty && Protocol.proper_status_elements(markup.name) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   266
                Some((markup :: markups, color))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   267
              case (_, Text.Info(_, XML.Elem(Markup(Markup.BAD, _), _))) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   268
                Some((Nil, Some(Rendering.Color.bad)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   269
              case (_, Text.Info(_, XML.Elem(Markup(Markup.INTENSIFY, _), _))) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   270
                Some((Nil, Some(Rendering.Color.intensify)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   271
              case (_, Text.Info(_, XML.Elem(Markup(Markup.ENTITY, props), _))) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   272
                props match {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   273
                  case Markup.Entity.Def(i) if focus(i) => Some((Nil, Some(Rendering.Color.entity)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   274
                  case Markup.Entity.Ref(i) if focus(i) => Some((Nil, Some(Rendering.Color.entity)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   275
                  case _ => None
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   276
                }
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   277
              case (_, Text.Info(_, XML.Elem(Markup.Markdown_Item(depth), _))) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   278
                val color =
65150
fa299b4e50c3 clarified rendering;
wenzelm
parents: 65149
diff changeset
   279
                  depth % 4 match {
65101
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   280
                    case 1 => Rendering.Color.markdown_item1
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   281
                    case 2 => Rendering.Color.markdown_item2
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   282
                    case 3 => Rendering.Color.markdown_item3
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   283
                    case _ => Rendering.Color.markdown_item4
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   284
                  }
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   285
                Some((Nil, Some(color)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   286
              case (acc, Text.Info(_, Protocol.Dialog(_, serial, result))) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   287
                command_states.collectFirst(
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   288
                  { case st if st.results.defined(serial) => st.results.get(serial).get }) match
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   289
                {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   290
                  case Some(Protocol.Dialog_Result(res)) if res == result =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   291
                    Some((Nil, Some(Rendering.Color.active_result)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   292
                  case _ =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   293
                    Some((Nil, Some(Rendering.Color.active)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   294
                }
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   295
              case (_, Text.Info(_, elem)) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   296
                if (Rendering.active_elements(elem.name))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   297
                  Some((Nil, Some(Rendering.Color.active)))
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   298
                else None
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   299
            })
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   300
      color <-
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   301
        (result match {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   302
          case (markups, opt_color) if markups.nonEmpty =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   303
            val status = Protocol.Status.make(markups.iterator)
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   304
            if (status.is_unprocessed) Some(Rendering.Color.unprocessed1)
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   305
            else if (status.is_running) Some(Rendering.Color.running1)
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   306
            else opt_color
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   307
          case (_, opt_color) => opt_color
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   308
        })
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   309
    } yield Text.Info(r, color)
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   310
  }
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   311
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   312
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   313
  /* text foreground */
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   314
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   315
  def foreground(range: Text.Range): List[Text.Info[Rendering.Color.Value]] =
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   316
    snapshot.select(range, Rendering.foreground_elements, _ =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   317
      {
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   318
        case Text.Info(_, elem) =>
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   319
          if (elem.name == Markup.ANTIQUOTED) Some(Rendering.Color.antiquoted)
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   320
          else Some(Rendering.Color.quoted)
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   321
      })
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   322
4263b2a201b3 symbolic Rendering.Color;
wenzelm
parents: 64877
diff changeset
   323
64767
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   324
  /* caret focus */
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   325
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   326
  private def entity_focus(range: Text.Range,
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   327
    check: (Boolean, Long) => Boolean = (is_def: Boolean, i: Long) => is_def): Set[Long] =
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   328
  {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   329
    val results =
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   330
      snapshot.cumulate[Set[Long]](range, Set.empty, Rendering.caret_focus_elements, _ =>
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   331
          {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   332
            case (serials, Text.Info(_, XML.Elem(Markup(Markup.ENTITY, props), _))) =>
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   333
              props match {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   334
                case Markup.Entity.Def(i) if check(true, i) => Some(serials + i)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   335
                case Markup.Entity.Ref(i) if check(false, i) => Some(serials + i)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   336
                case _ => None
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   337
              }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   338
            case _ => None
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   339
          })
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   340
    (Set.empty[Long] /: results){ case (s1, Text.Info(_, s2)) => s1 ++ s2 }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   341
  }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   342
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   343
  def caret_focus(caret_range: Text.Range, visible_range: Text.Range): Set[Long] =
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   344
  {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   345
    val focus_defs = entity_focus(caret_range)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   346
    if (focus_defs.nonEmpty) focus_defs
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   347
    else {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   348
      val visible_defs = entity_focus(visible_range)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   349
      entity_focus(caret_range, (is_def: Boolean, i: Long) => !is_def && visible_defs.contains(i))
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   350
    }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   351
  }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   352
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   353
  def caret_focus_ranges(caret_range: Text.Range, visible_range: Text.Range): List[Text.Range] =
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   354
  {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   355
    val focus = caret_focus(caret_range, visible_range)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   356
    if (focus.nonEmpty) {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   357
      val results =
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   358
        snapshot.cumulate[Boolean](visible_range, false, Rendering.caret_focus_elements, _ =>
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   359
          {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   360
            case (_, Text.Info(_, XML.Elem(Markup(Markup.ENTITY, props), _))) =>
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   361
              props match {
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   362
                case Markup.Entity.Def(i) if focus(i) => Some(true)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   363
                case Markup.Entity.Ref(i) if focus(i) => Some(true)
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   364
                case _ => None
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   365
              }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   366
          })
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   367
      for (info <- results if info.info) yield info.range
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   368
    }
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   369
    else Nil
f5c4ffdb1124 support VSCode DocumentHighlights;
wenzelm
parents: 64748
diff changeset
   370
  }
65121
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   371
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   372
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   373
  /* message underline color */
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   374
65129
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   375
  def message_underline_color(elements: Markup.Elements, range: Text.Range)
06a7c2d316cf more general tooltips, with uniform info range handling;
wenzelm
parents: 65126
diff changeset
   376
    : List[Text.Info[Rendering.Color.Value]] =
65121
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   377
  {
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   378
    val results =
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   379
      snapshot.cumulate[Int](range, 0, elements, _ =>
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   380
        {
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   381
          case (pri, Text.Info(_, elem)) => Some(pri max Rendering.message_pri(elem.name))
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   382
        })
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   383
    for {
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   384
      Text.Info(r, pri) <- results
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   385
      color <- Rendering.message_underline_color.get(pri)
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   386
    } yield Text.Info(r, color)
12c6774a8f65 more generic rendering;
wenzelm
parents: 65107
diff changeset
   387
  }
65149
wenzelm
parents: 65145
diff changeset
   388
wenzelm
parents: 65145
diff changeset
   389
wenzelm
parents: 65145
diff changeset
   390
  /* tooltips */
wenzelm
parents: 65145
diff changeset
   391
wenzelm
parents: 65145
diff changeset
   392
  def timing_threshold: Double
wenzelm
parents: 65145
diff changeset
   393
wenzelm
parents: 65145
diff changeset
   394
  private sealed case class Tooltip_Info(
wenzelm
parents: 65145
diff changeset
   395
    range: Text.Range,
wenzelm
parents: 65145
diff changeset
   396
    timing: Timing = Timing.zero,
wenzelm
parents: 65145
diff changeset
   397
    messages: List[Command.Results.Entry] = Nil,
wenzelm
parents: 65145
diff changeset
   398
    rev_infos: List[(Boolean, XML.Tree)] = Nil)
wenzelm
parents: 65145
diff changeset
   399
  {
wenzelm
parents: 65145
diff changeset
   400
    def + (t: Timing): Tooltip_Info = copy(timing = timing + t)
wenzelm
parents: 65145
diff changeset
   401
    def + (r0: Text.Range, serial: Long, tree: XML.Tree): Tooltip_Info =
wenzelm
parents: 65145
diff changeset
   402
    {
wenzelm
parents: 65145
diff changeset
   403
      val r = snapshot.convert(r0)
wenzelm
parents: 65145
diff changeset
   404
      if (range == r) copy(messages = (serial -> tree) :: messages)
wenzelm
parents: 65145
diff changeset
   405
      else copy(range = r, messages = List(serial -> tree))
wenzelm
parents: 65145
diff changeset
   406
    }
wenzelm
parents: 65145
diff changeset
   407
    def + (r0: Text.Range, important: Boolean, tree: XML.Tree): Tooltip_Info =
wenzelm
parents: 65145
diff changeset
   408
    {
wenzelm
parents: 65145
diff changeset
   409
      val r = snapshot.convert(r0)
wenzelm
parents: 65145
diff changeset
   410
      if (range == r) copy(rev_infos = (important -> tree) :: rev_infos)
wenzelm
parents: 65145
diff changeset
   411
      else copy (range = r, rev_infos = List(important -> tree))
wenzelm
parents: 65145
diff changeset
   412
    }
wenzelm
parents: 65145
diff changeset
   413
    def infos(important: Boolean): List[XML.Tree] =
wenzelm
parents: 65145
diff changeset
   414
      rev_infos.filter(p => p._1 == important).reverse.map(_._2)
wenzelm
parents: 65145
diff changeset
   415
  }
wenzelm
parents: 65145
diff changeset
   416
wenzelm
parents: 65145
diff changeset
   417
  def tooltips(elements: Markup.Elements, range: Text.Range): Option[Text.Info[List[XML.Tree]]] =
wenzelm
parents: 65145
diff changeset
   418
  {
wenzelm
parents: 65145
diff changeset
   419
    val results =
wenzelm
parents: 65145
diff changeset
   420
      snapshot.cumulate[Tooltip_Info](range, Tooltip_Info(range), elements, _ =>
wenzelm
parents: 65145
diff changeset
   421
        {
wenzelm
parents: 65145
diff changeset
   422
          case (info, Text.Info(_, XML.Elem(Markup.Timing(t), _))) => Some(info + t)
wenzelm
parents: 65145
diff changeset
   423
wenzelm
parents: 65145
diff changeset
   424
          case (info, Text.Info(r0, XML.Elem(Markup(name, props @ Markup.Serial(serial)), body)))
wenzelm
parents: 65145
diff changeset
   425
          if Rendering.tooltip_message_elements(name) && body.nonEmpty =>
wenzelm
parents: 65145
diff changeset
   426
            Some(info + (r0, serial, XML.Elem(Markup(Markup.message(name), props), body)))
wenzelm
parents: 65145
diff changeset
   427
wenzelm
parents: 65145
diff changeset
   428
          case (info, Text.Info(r0, XML.Elem(Markup.Entity(kind, name), _)))
wenzelm
parents: 65145
diff changeset
   429
          if kind != "" && kind != Markup.ML_DEF =>
wenzelm
parents: 65145
diff changeset
   430
            val kind1 = Word.implode(Word.explode('_', kind))
wenzelm
parents: 65145
diff changeset
   431
            val txt1 =
wenzelm
parents: 65145
diff changeset
   432
              if (name == "") kind1
wenzelm
parents: 65145
diff changeset
   433
              else if (kind1 == "") quote(name)
wenzelm
parents: 65145
diff changeset
   434
              else kind1 + " " + quote(name)
wenzelm
parents: 65145
diff changeset
   435
            val txt2 =
wenzelm
parents: 65145
diff changeset
   436
              if (kind == Markup.COMMAND && info.timing.elapsed.seconds >= timing_threshold)
wenzelm
parents: 65145
diff changeset
   437
                "\n" + info.timing.message
wenzelm
parents: 65145
diff changeset
   438
              else ""
wenzelm
parents: 65145
diff changeset
   439
            Some(info + (r0, true, XML.Text(txt1 + txt2)))
wenzelm
parents: 65145
diff changeset
   440
wenzelm
parents: 65145
diff changeset
   441
          case (info, Text.Info(r0, XML.Elem(Markup.Path(name), _))) =>
wenzelm
parents: 65145
diff changeset
   442
            val file = resources.append_file(snapshot.node_name.master_dir, name)
wenzelm
parents: 65145
diff changeset
   443
            val text =
wenzelm
parents: 65145
diff changeset
   444
              if (name == file) "file " + quote(file)
wenzelm
parents: 65145
diff changeset
   445
              else "path " + quote(name) + "\nfile " + quote(file)
wenzelm
parents: 65145
diff changeset
   446
            Some(info + (r0, true, XML.Text(text)))
wenzelm
parents: 65145
diff changeset
   447
wenzelm
parents: 65145
diff changeset
   448
          case (info, Text.Info(r0, XML.Elem(Markup.Doc(name), _))) =>
wenzelm
parents: 65145
diff changeset
   449
            val text = "doc " + quote(name)
wenzelm
parents: 65145
diff changeset
   450
            Some(info + (r0, true, XML.Text(text)))
wenzelm
parents: 65145
diff changeset
   451
wenzelm
parents: 65145
diff changeset
   452
          case (info, Text.Info(r0, XML.Elem(Markup.Url(name), _))) =>
wenzelm
parents: 65145
diff changeset
   453
            Some(info + (r0, true, XML.Text("URL " + quote(name))))
wenzelm
parents: 65145
diff changeset
   454
wenzelm
parents: 65145
diff changeset
   455
          case (info, Text.Info(r0, XML.Elem(Markup(name, _), body)))
wenzelm
parents: 65145
diff changeset
   456
          if name == Markup.SORTING || name == Markup.TYPING =>
wenzelm
parents: 65145
diff changeset
   457
            Some(info + (r0, true, Pretty.block(XML.Text("::") :: Pretty.brk(1) :: body)))
wenzelm
parents: 65145
diff changeset
   458
wenzelm
parents: 65145
diff changeset
   459
          case (info, Text.Info(r0, XML.Elem(Markup(Markup.CLASS_PARAMETER, _), body))) =>
wenzelm
parents: 65145
diff changeset
   460
            Some(info + (r0, true, Pretty.block(0, body)))
wenzelm
parents: 65145
diff changeset
   461
wenzelm
parents: 65145
diff changeset
   462
          case (info, Text.Info(r0, XML.Elem(Markup(Markup.ML_TYPING, _), body))) =>
wenzelm
parents: 65145
diff changeset
   463
            Some(info + (r0, false, Pretty.block(XML.Text("ML:") :: Pretty.brk(1) :: body)))
wenzelm
parents: 65145
diff changeset
   464
wenzelm
parents: 65145
diff changeset
   465
          case (info, Text.Info(r0, Protocol.ML_Breakpoint(breakpoint))) =>
wenzelm
parents: 65145
diff changeset
   466
            val text =
wenzelm
parents: 65145
diff changeset
   467
              if (Debugger.breakpoint_state(breakpoint)) "breakpoint (enabled)"
wenzelm
parents: 65145
diff changeset
   468
              else "breakpoint (disabled)"
wenzelm
parents: 65145
diff changeset
   469
            Some(info + (r0, true, XML.Text(text)))
wenzelm
parents: 65145
diff changeset
   470
wenzelm
parents: 65145
diff changeset
   471
          case (info, Text.Info(r0, XML.Elem(Markup.Language(language, _, _, _), _))) =>
wenzelm
parents: 65145
diff changeset
   472
            val lang = Word.implode(Word.explode('_', language))
wenzelm
parents: 65145
diff changeset
   473
            Some(info + (r0, true, XML.Text("language: " + lang)))
wenzelm
parents: 65145
diff changeset
   474
wenzelm
parents: 65145
diff changeset
   475
          case (info, Text.Info(r0, XML.Elem(Markup.Expression(kind), _))) =>
wenzelm
parents: 65145
diff changeset
   476
            val descr = if (kind == "") "expression" else "expression: " + kind
wenzelm
parents: 65145
diff changeset
   477
            Some(info + (r0, true, XML.Text(descr)))
wenzelm
parents: 65145
diff changeset
   478
wenzelm
parents: 65145
diff changeset
   479
          case (info, Text.Info(r0, XML.Elem(Markup(Markup.MARKDOWN_PARAGRAPH, _), _))) =>
wenzelm
parents: 65145
diff changeset
   480
            Some(info + (r0, true, XML.Text("Markdown: paragraph")))
wenzelm
parents: 65145
diff changeset
   481
          case (info, Text.Info(r0, XML.Elem(Markup.Markdown_List(kind), _))) =>
wenzelm
parents: 65145
diff changeset
   482
            Some(info + (r0, true, XML.Text("Markdown: " + kind)))
wenzelm
parents: 65145
diff changeset
   483
wenzelm
parents: 65145
diff changeset
   484
          case (info, Text.Info(r0, XML.Elem(Markup(name, _), _))) =>
wenzelm
parents: 65145
diff changeset
   485
            Rendering.tooltip_descriptions.get(name).map(desc => info + (r0, true, XML.Text(desc)))
wenzelm
parents: 65145
diff changeset
   486
        }).map(_.info)
wenzelm
parents: 65145
diff changeset
   487
wenzelm
parents: 65145
diff changeset
   488
    if (results.isEmpty) None
wenzelm
parents: 65145
diff changeset
   489
    else {
wenzelm
parents: 65145
diff changeset
   490
      val r = Text.Range(results.head.range.start, results.last.range.stop)
wenzelm
parents: 65145
diff changeset
   491
      val all_tips =
wenzelm
parents: 65145
diff changeset
   492
        Command.Results.make(results.flatMap(_.messages)).iterator.map(_._2).toList :::
wenzelm
parents: 65145
diff changeset
   493
        results.flatMap(res => res.infos(true)) :::
wenzelm
parents: 65145
diff changeset
   494
        results.flatMap(res => res.infos(false)).lastOption.toList
wenzelm
parents: 65145
diff changeset
   495
      if (all_tips.isEmpty) None else Some(Text.Info(r, all_tips))
wenzelm
parents: 65145
diff changeset
   496
    }
wenzelm
parents: 65145
diff changeset
   497
  }
64622
529bbb8977c7 more uniform rendering for Isabelle/jEdit and Isabelle/VSCode;
wenzelm
parents:
diff changeset
   498
}