src/Pure/PIDE/markup.scala
author wenzelm
Tue Apr 09 20:16:52 2013 +0200 (2013-04-09 ago)
changeset 51662 3391a493f39a
parent 51574 2b58d7b139d6
child 51818 517f232e867d
permissions -rw-r--r--
just one timing protocol function, with 3 implementations: TTY/PG, PIDE/document, build;
wenzelm@45670
     1
/*  Title:      Pure/PIDE/markup.scala
wenzelm@45673
     2
    Module:     PIDE
wenzelm@27958
     3
    Author:     Makarius
wenzelm@27958
     4
wenzelm@50201
     5
Isabelle-specific implementation of quasi-abstract markup elements.
wenzelm@27958
     6
*/
wenzelm@27958
     7
wenzelm@27958
     8
package isabelle
wenzelm@27958
     9
wenzelm@27970
    10
wenzelm@32450
    11
object Markup
wenzelm@32450
    12
{
wenzelm@45666
    13
  /* properties */
wenzelm@29184
    14
wenzelm@29184
    15
  val NAME = "name"
wenzelm@43780
    16
  val Name = new Properties.String(NAME)
wenzelm@42136
    17
wenzelm@29184
    18
  val KIND = "kind"
wenzelm@43780
    19
  val Kind = new Properties.String(KIND)
wenzelm@29184
    20
wenzelm@29184
    21
wenzelm@50201
    22
  /* basic markup */
wenzelm@29184
    23
wenzelm@45666
    24
  val Empty = Markup("", Nil)
wenzelm@45666
    25
  val Broken = Markup("broken", Nil)
wenzelm@50201
    26
wenzelm@50201
    27
wenzelm@50201
    28
  /* formal entities */
wenzelm@50201
    29
wenzelm@50201
    30
  val BINDING = "binding"
wenzelm@50201
    31
  val ENTITY = "entity"
wenzelm@50201
    32
  val DEF = "def"
wenzelm@50201
    33
  val REF = "ref"
wenzelm@50201
    34
wenzelm@50201
    35
  object Entity
wenzelm@50201
    36
  {
wenzelm@50201
    37
    def unapply(markup: Markup): Option[(String, String)] =
wenzelm@50201
    38
      markup match {
wenzelm@50201
    39
        case Markup(ENTITY, props @ Kind(kind)) =>
wenzelm@50201
    40
          props match {
wenzelm@50201
    41
            case Name(name) => Some(kind, name)
wenzelm@50201
    42
            case _ => None
wenzelm@50201
    43
          }
wenzelm@50201
    44
        case _ => None
wenzelm@50201
    45
      }
wenzelm@50201
    46
  }
wenzelm@50201
    47
wenzelm@50201
    48
wenzelm@50201
    49
  /* position */
wenzelm@50201
    50
wenzelm@50201
    51
  val LINE = "line"
wenzelm@50201
    52
  val OFFSET = "offset"
wenzelm@50201
    53
  val END_OFFSET = "end_offset"
wenzelm@50201
    54
  val FILE = "file"
wenzelm@50201
    55
  val ID = "id"
wenzelm@50201
    56
wenzelm@50201
    57
  val DEF_LINE = "def_line"
wenzelm@50201
    58
  val DEF_OFFSET = "def_offset"
wenzelm@50201
    59
  val DEF_END_OFFSET = "def_end_offset"
wenzelm@50201
    60
  val DEF_FILE = "def_file"
wenzelm@50201
    61
  val DEF_ID = "def_id"
wenzelm@50201
    62
wenzelm@50201
    63
  val POSITION_PROPERTIES = Set(LINE, OFFSET, END_OFFSET, FILE, ID)
wenzelm@50201
    64
  val POSITION = "position"
wenzelm@50201
    65
wenzelm@50201
    66
wenzelm@50201
    67
  /* path */
wenzelm@50201
    68
wenzelm@50201
    69
  val PATH = "path"
wenzelm@50201
    70
wenzelm@50201
    71
  object Path
wenzelm@50201
    72
  {
wenzelm@50201
    73
    def unapply(markup: Markup): Option[String] =
wenzelm@50201
    74
      markup match {
wenzelm@50201
    75
        case Markup(PATH, Name(name)) => Some(name)
wenzelm@50201
    76
        case _ => None
wenzelm@50201
    77
      }
wenzelm@50201
    78
  }
wenzelm@50201
    79
wenzelm@50201
    80
wenzelm@50201
    81
  /* pretty printing */
wenzelm@50201
    82
wenzelm@50201
    83
  val Indent = new Properties.Int("indent")
wenzelm@50201
    84
  val BLOCK = "block"
wenzelm@51570
    85
wenzelm@50201
    86
  val Width = new Properties.Int("width")
wenzelm@50201
    87
  val BREAK = "break"
wenzelm@50201
    88
wenzelm@51570
    89
  val ITEM = "item"
wenzelm@51574
    90
  val BULLET = "bullet"
wenzelm@51570
    91
wenzelm@50201
    92
  val SEPARATOR = "separator"
wenzelm@50201
    93
wenzelm@50201
    94
wenzelm@50201
    95
  /* hidden text */
wenzelm@50201
    96
wenzelm@50201
    97
  val HIDDEN = "hidden"
wenzelm@50201
    98
wenzelm@50201
    99
wenzelm@50201
   100
  /* logical entities */
wenzelm@50201
   101
wenzelm@50201
   102
  val CLASS = "class"
wenzelm@50201
   103
  val TYPE_NAME = "type_name"
wenzelm@50201
   104
  val FIXED = "fixed"
wenzelm@50201
   105
  val CONSTANT = "constant"
wenzelm@50201
   106
wenzelm@50201
   107
  val DYNAMIC_FACT = "dynamic_fact"
wenzelm@50201
   108
wenzelm@50201
   109
wenzelm@50201
   110
  /* inner syntax */
wenzelm@50201
   111
wenzelm@50201
   112
  val TFREE = "tfree"
wenzelm@50201
   113
  val TVAR = "tvar"
wenzelm@50201
   114
  val FREE = "free"
wenzelm@50201
   115
  val SKOLEM = "skolem"
wenzelm@50201
   116
  val BOUND = "bound"
wenzelm@50201
   117
  val VAR = "var"
wenzelm@50201
   118
  val NUMERAL = "numeral"
wenzelm@50201
   119
  val LITERAL = "literal"
wenzelm@50201
   120
  val DELIMITER = "delimiter"
wenzelm@50201
   121
  val INNER_STRING = "inner_string"
wenzelm@50201
   122
  val INNER_COMMENT = "inner_comment"
wenzelm@50201
   123
wenzelm@50201
   124
  val TOKEN_RANGE = "token_range"
wenzelm@50201
   125
wenzelm@50201
   126
  val SORT = "sort"
wenzelm@50201
   127
  val TYP = "typ"
wenzelm@50201
   128
  val TERM = "term"
wenzelm@50201
   129
  val PROP = "prop"
wenzelm@50201
   130
wenzelm@50201
   131
  val SORTING = "sorting"
wenzelm@50201
   132
  val TYPING = "typing"
wenzelm@50201
   133
wenzelm@50201
   134
  val ATTRIBUTE = "attribute"
wenzelm@50201
   135
  val METHOD = "method"
wenzelm@50201
   136
wenzelm@50201
   137
wenzelm@50201
   138
  /* embedded source text */
wenzelm@50201
   139
wenzelm@50201
   140
  val ML_SOURCE = "ML_source"
wenzelm@50201
   141
  val DOCUMENT_SOURCE = "document_source"
wenzelm@50201
   142
wenzelm@50201
   143
  val ANTIQ = "antiq"
wenzelm@50201
   144
  val ML_ANTIQUOTATION = "ML_antiquotation"
wenzelm@50201
   145
  val DOCUMENT_ANTIQUOTATION = "document_antiquotation"
wenzelm@50201
   146
  val DOCUMENT_ANTIQUOTATION_OPTION = "document_antiquotation_option"
wenzelm@50201
   147
wenzelm@50201
   148
wenzelm@50201
   149
  /* text structure */
wenzelm@50201
   150
wenzelm@50201
   151
  val PARAGRAPH = "paragraph"
wenzelm@50545
   152
  val TEXT_FOLD = "text_fold"
wenzelm@50201
   153
wenzelm@50201
   154
wenzelm@50201
   155
  /* ML syntax */
wenzelm@50201
   156
wenzelm@50201
   157
  val ML_KEYWORD = "ML_keyword"
wenzelm@50201
   158
  val ML_DELIMITER = "ML_delimiter"
wenzelm@50201
   159
  val ML_TVAR = "ML_tvar"
wenzelm@50201
   160
  val ML_NUMERAL = "ML_numeral"
wenzelm@50201
   161
  val ML_CHAR = "ML_char"
wenzelm@50201
   162
  val ML_STRING = "ML_string"
wenzelm@50201
   163
  val ML_COMMENT = "ML_comment"
wenzelm@50201
   164
wenzelm@50201
   165
  val ML_DEF = "ML_def"
wenzelm@50201
   166
  val ML_OPEN = "ML_open"
wenzelm@50201
   167
  val ML_STRUCT = "ML_struct"
wenzelm@50201
   168
  val ML_TYPING = "ML_typing"
wenzelm@50201
   169
wenzelm@50201
   170
wenzelm@50201
   171
  /* outer syntax */
wenzelm@50201
   172
wenzelm@50201
   173
  val KEYWORD = "keyword"
wenzelm@50201
   174
  val OPERATOR = "operator"
wenzelm@50201
   175
  val COMMAND = "command"
wenzelm@50201
   176
  val STRING = "string"
wenzelm@50201
   177
  val ALTSTRING = "altstring"
wenzelm@50201
   178
  val VERBATIM = "verbatim"
wenzelm@50201
   179
  val COMMENT = "comment"
wenzelm@50201
   180
  val CONTROL = "control"
wenzelm@50201
   181
wenzelm@50201
   182
  val KEYWORD1 = "keyword1"
wenzelm@50201
   183
  val KEYWORD2 = "keyword2"
wenzelm@50201
   184
wenzelm@50201
   185
wenzelm@50201
   186
  /* timing */
wenzelm@50201
   187
wenzelm@50781
   188
  val Elapsed = new Properties.Double("elapsed")
wenzelm@50781
   189
  val CPU = new Properties.Double("cpu")
wenzelm@50781
   190
  val GC = new Properties.Double("gc")
wenzelm@50781
   191
wenzelm@50781
   192
  object Timing_Properties
wenzelm@50781
   193
  {
wenzelm@50781
   194
    def apply(timing: isabelle.Timing): Properties.T =
wenzelm@50781
   195
      Elapsed(timing.elapsed.seconds) ::: CPU(timing.cpu.seconds) ::: GC(timing.gc.seconds)
wenzelm@51662
   196
wenzelm@50781
   197
    def unapply(props: Properties.T): Option[isabelle.Timing] =
wenzelm@50781
   198
      (props, props, props) match {
wenzelm@50781
   199
        case (Elapsed(elapsed), CPU(cpu), GC(gc)) =>
wenzelm@50781
   200
          Some(new isabelle.Timing(Time.seconds(elapsed), Time.seconds(cpu), Time.seconds(gc)))
wenzelm@50781
   201
        case _ => None
wenzelm@50781
   202
      }
wenzelm@50781
   203
  }
wenzelm@50781
   204
wenzelm@50201
   205
  val TIMING = "timing"
wenzelm@50201
   206
wenzelm@50201
   207
  object Timing
wenzelm@50201
   208
  {
wenzelm@50781
   209
    def apply(timing: isabelle.Timing): Markup = Markup(TIMING, Timing_Properties(timing))
wenzelm@51662
   210
wenzelm@50201
   211
    def unapply(markup: Markup): Option[isabelle.Timing] =
wenzelm@50201
   212
      markup match {
wenzelm@50781
   213
        case Markup(TIMING, Timing_Properties(timing)) => Some(timing)
wenzelm@50201
   214
        case _ => None
wenzelm@50201
   215
      }
wenzelm@50201
   216
  }
wenzelm@50201
   217
wenzelm@50201
   218
wenzelm@51662
   219
  /* command timing */
wenzelm@51662
   220
wenzelm@51662
   221
  object Command_Timing
wenzelm@51662
   222
  {
wenzelm@51662
   223
    def unapply(props: Properties.T): Option[(Document.ID, isabelle.Timing)] =
wenzelm@51662
   224
      props match {
wenzelm@51662
   225
        case (FUNCTION, "command_timing") :: args =>
wenzelm@51662
   226
          (args, args) match {
wenzelm@51662
   227
            case (Position.Id(id), Timing_Properties(timing)) => Some((id, timing))
wenzelm@51662
   228
            case _ => None
wenzelm@51662
   229
          }
wenzelm@51662
   230
        case _ => None
wenzelm@51662
   231
      }
wenzelm@51662
   232
  }
wenzelm@51662
   233
wenzelm@51662
   234
wenzelm@50201
   235
  /* toplevel */
wenzelm@50201
   236
wenzelm@50201
   237
  val SUBGOALS = "subgoals"
wenzelm@50201
   238
  val PROOF_STATE = "proof_state"
wenzelm@50201
   239
wenzelm@50201
   240
  val STATE = "state"
wenzelm@50543
   241
  val GOAL = "goal"
wenzelm@50201
   242
  val SUBGOAL = "subgoal"
wenzelm@50215
   243
wenzelm@50450
   244
wenzelm@50201
   245
  /* command status */
wenzelm@50201
   246
wenzelm@50201
   247
  val TASK = "task"
wenzelm@50201
   248
wenzelm@50201
   249
  val ACCEPTED = "accepted"
wenzelm@50201
   250
  val FORKED = "forked"
wenzelm@50201
   251
  val JOINED = "joined"
wenzelm@50201
   252
  val RUNNING = "running"
wenzelm@50201
   253
  val FINISHED = "finished"
wenzelm@50201
   254
  val FAILED = "failed"
wenzelm@50201
   255
wenzelm@50201
   256
wenzelm@50201
   257
  /* interactive documents */
wenzelm@50201
   258
wenzelm@50201
   259
  val VERSION = "version"
wenzelm@50201
   260
  val ASSIGN = "assign"
wenzelm@50201
   261
wenzelm@50201
   262
wenzelm@50201
   263
  /* prover process */
wenzelm@50201
   264
wenzelm@50201
   265
  val PROVER_COMMAND = "prover_command"
wenzelm@50201
   266
  val PROVER_ARG = "prover_arg"
wenzelm@50201
   267
wenzelm@50201
   268
wenzelm@50201
   269
  /* messages */
wenzelm@50201
   270
wenzelm@50201
   271
  val Serial = new Properties.Long("serial")
wenzelm@50201
   272
wenzelm@50201
   273
  val MESSAGE = "message"
wenzelm@50201
   274
wenzelm@50201
   275
  val INIT = "init"
wenzelm@50201
   276
  val STATUS = "status"
wenzelm@50201
   277
  val REPORT = "report"
wenzelm@50500
   278
  val RESULT = "result"
wenzelm@50201
   279
  val WRITELN = "writeln"
wenzelm@50201
   280
  val TRACING = "tracing"
wenzelm@50201
   281
  val WARNING = "warning"
wenzelm@50201
   282
  val ERROR = "error"
wenzelm@50201
   283
  val PROTOCOL = "protocol"
wenzelm@50201
   284
  val SYSTEM = "system"
wenzelm@50201
   285
  val STDOUT = "stdout"
wenzelm@50201
   286
  val STDERR = "stderr"
wenzelm@50201
   287
  val EXIT = "exit"
wenzelm@50201
   288
wenzelm@50201
   289
  val WRITELN_MESSAGE = "writeln_message"
wenzelm@50201
   290
  val TRACING_MESSAGE = "tracing_message"
wenzelm@50201
   291
  val WARNING_MESSAGE = "warning_message"
wenzelm@50201
   292
  val ERROR_MESSAGE = "error_message"
wenzelm@50201
   293
wenzelm@50201
   294
  val message: String => String =
wenzelm@50201
   295
    Map(WRITELN -> WRITELN_MESSAGE, TRACING -> TRACING_MESSAGE,
wenzelm@50501
   296
        WARNING -> WARNING_MESSAGE, ERROR -> ERROR_MESSAGE).withDefault((s: String) => s)
wenzelm@50201
   297
wenzelm@50201
   298
  val Return_Code = new Properties.Int("return_code")
wenzelm@50201
   299
wenzelm@50201
   300
  val LEGACY = "legacy"
wenzelm@50201
   301
wenzelm@50201
   302
  val NO_REPORT = "no_report"
wenzelm@50201
   303
wenzelm@50201
   304
  val BAD = "bad"
wenzelm@50201
   305
wenzelm@50500
   306
  val INTENSIFY = "intensify"
wenzelm@50500
   307
wenzelm@50500
   308
wenzelm@50500
   309
  /* active areas */
wenzelm@50500
   310
wenzelm@50715
   311
  val BROWSER = "browser"
wenzelm@50500
   312
  val GRAPHVIEW = "graphview"
wenzelm@50500
   313
wenzelm@50500
   314
  val SENDBACK = "sendback"
wenzelm@50500
   315
  val PADDING = "padding"
wenzelm@50500
   316
  val PADDING_LINE = (PADDING, LINE)
wenzelm@50500
   317
wenzelm@50500
   318
  val DIALOG = "dialog"
wenzelm@50503
   319
  val Result = new Properties.String(RESULT)
wenzelm@50500
   320
wenzelm@50201
   321
wenzelm@50201
   322
  /* protocol message functions */
wenzelm@50201
   323
wenzelm@50201
   324
  val FUNCTION = "function"
wenzelm@50201
   325
  val Function = new Properties.String(FUNCTION)
wenzelm@50201
   326
wenzelm@50201
   327
  val Assign_Execs: Properties.T = List((FUNCTION, "assign_execs"))
wenzelm@50201
   328
  val Removed_Versions: Properties.T = List((FUNCTION, "removed_versions"))
wenzelm@50201
   329
wenzelm@50201
   330
  object Invoke_Scala
wenzelm@50201
   331
  {
wenzelm@50201
   332
    def unapply(props: Properties.T): Option[(String, String)] =
wenzelm@50201
   333
      props match {
wenzelm@50201
   334
        case List((FUNCTION, "invoke_scala"), (NAME, name), (ID, id)) => Some((name, id))
wenzelm@50201
   335
        case _ => None
wenzelm@50201
   336
      }
wenzelm@50201
   337
  }
wenzelm@50201
   338
  object Cancel_Scala
wenzelm@50201
   339
  {
wenzelm@50201
   340
    def unapply(props: Properties.T): Option[String] =
wenzelm@50201
   341
      props match {
wenzelm@50201
   342
        case List((FUNCTION, "cancel_scala"), (ID, id)) => Some(id)
wenzelm@50201
   343
        case _ => None
wenzelm@50201
   344
      }
wenzelm@50201
   345
  }
wenzelm@50255
   346
wenzelm@50255
   347
  object ML_Statistics
wenzelm@50255
   348
  {
wenzelm@50255
   349
    def unapply(props: Properties.T): Option[Properties.T] =
wenzelm@50255
   350
      props match {
wenzelm@50255
   351
        case (FUNCTION, "ML_statistics") :: stats => Some(stats)
wenzelm@50255
   352
        case _ => None
wenzelm@50255
   353
      }
wenzelm@50255
   354
  }
wenzelm@50975
   355
wenzelm@50975
   356
  object Task_Statistics
wenzelm@50975
   357
  {
wenzelm@50975
   358
    def unapply(props: Properties.T): Option[Properties.T] =
wenzelm@50975
   359
      props match {
wenzelm@50975
   360
        case (FUNCTION, "task_statistics") :: stats => Some(stats)
wenzelm@50975
   361
        case _ => None
wenzelm@50975
   362
      }
wenzelm@50975
   363
  }
wenzelm@45666
   364
}
wenzelm@43721
   365
wenzelm@43721
   366
wenzelm@45666
   367
sealed case class Markup(name: String, properties: Properties.T)
wenzelm@43748
   368