src/Pure/Isar/keyword.scala
author wenzelm
Sun, 19 Nov 2023 12:46:41 +0100
changeset 78991 ae2f5fd0bb5d
parent 77368 7c57d9586f4c
permissions -rw-r--r--
clarified signature and modules: more explicit Build_Log.History;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
36947
285b39022372 renamed Outer_Keyword to Keyword (in Scala);
wenzelm
parents: 36681
diff changeset
     1
/*  Title:      Pure/Isar/keyword.scala
29449
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     3
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
     4
Isar keyword classification.
29449
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     5
*/
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     6
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     7
package isabelle
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     8
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
     9
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    10
object Keyword {
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
    11
  /** keyword classification **/
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
    12
36681
dffeca08d3bf extractors for outer keyword declarations;
wenzelm
parents: 34166
diff changeset
    13
  /* kinds */
dffeca08d3bf extractors for outer keyword declarations;
wenzelm
parents: 34166
diff changeset
    14
29449
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
    15
  val DIAG = "diag"
58999
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    16
  val DOCUMENT_HEADING = "document_heading"
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    17
  val DOCUMENT_BODY = "document_body"
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    18
  val DOCUMENT_RAW = "document_raw"
46967
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    19
  val THY_BEGIN = "thy_begin"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    20
  val THY_END = "thy_end"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    21
  val THY_DECL = "thy_decl"
58800
bfed1c26caed explicit keyword category for commands that may start a block;
wenzelm
parents: 57837
diff changeset
    22
  val THY_DECL_BLOCK = "thy_decl_block"
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    23
  val THY_DEFN = "thy_defn"
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    24
  val THY_STMT = "thy_stmt"
48867
e9beabf045ab some support for inlining file content into outer syntax token language;
wenzelm
parents: 46969
diff changeset
    25
  val THY_LOAD = "thy_load"
46967
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    26
  val THY_GOAL = "thy_goal"
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    27
  val THY_GOAL_DEFN = "thy_goal_defn"
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    28
  val THY_GOAL_STMT = "thy_goal_stmt"
29449
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
    29
  val QED = "qed"
53571
e58ca0311c0f more explicit indication of 'done' as proof script element;
wenzelm
parents: 53371
diff changeset
    30
  val QED_SCRIPT = "qed_script"
46967
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    31
  val QED_BLOCK = "qed_block"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    32
  val QED_GLOBAL = "qed_global"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    33
  val PRF_GOAL = "prf_goal"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    34
  val PRF_BLOCK = "prf_block"
60694
b3fa4a8cdb5f clarified text folds: proof ... qed counts as extra block;
wenzelm
parents: 60692
diff changeset
    35
  val NEXT_BLOCK = "next_block"
46967
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    36
  val PRF_OPEN = "prf_open"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    37
  val PRF_CLOSE = "prf_close"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    38
  val PRF_CHAIN = "prf_chain"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    39
  val PRF_DECL = "prf_decl"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    40
  val PRF_ASM = "prf_asm"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    41
  val PRF_ASM_GOAL = "prf_asm_goal"
499d9bbd8de9 uniform keyword names within ML/Scala -- produce elisp names via external conversion;
wenzelm
parents: 46123
diff changeset
    42
  val PRF_SCRIPT = "prf_script"
60624
5b6552e12421 clarified keyword categories;
wenzelm
parents: 59701
diff changeset
    43
  val PRF_SCRIPT_GOAL = "prf_script_goal"
5b6552e12421 clarified keyword categories;
wenzelm
parents: 59701
diff changeset
    44
  val PRF_SCRIPT_ASM_GOAL = "prf_script_asm_goal"
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
    45
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
    46
  val BEFORE_COMMAND = "before_command"
63430
9c5fcd355a2d support for quasi_command keywords;
wenzelm
parents: 63429
diff changeset
    47
  val QUASI_COMMAND = "quasi_command"
29449
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
    48
36681
dffeca08d3bf extractors for outer keyword declarations;
wenzelm
parents: 34166
diff changeset
    49
59700
d887abcc7c24 more command categories, as in ML;
wenzelm
parents: 59122
diff changeset
    50
  /* command categories */
36681
dffeca08d3bf extractors for outer keyword declarations;
wenzelm
parents: 34166
diff changeset
    51
70123
b256f67e9d27 tuned signature according to ML version;
wenzelm
parents: 69917
diff changeset
    52
  val vacuous = Set(DIAG, DOCUMENT_HEADING, DOCUMENT_BODY, DOCUMENT_RAW)
58999
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    53
57835
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    54
  val diag = Set(DIAG)
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    55
58999
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    56
  val document_heading = Set(DOCUMENT_HEADING)
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    57
  val document_body = Set(DOCUMENT_BODY)
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    58
  val document_raw = Set(DOCUMENT_RAW)
ed09ae4ea2d8 uniform treatment of all document markup commands: 'text' and 'txt' merely differ in LaTeX style;
wenzelm
parents: 58928
diff changeset
    59
  val document = Set(DOCUMENT_HEADING, DOCUMENT_BODY, DOCUMENT_RAW)
57835
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    60
59700
d887abcc7c24 more command categories, as in ML;
wenzelm
parents: 59122
diff changeset
    61
  val theory_begin = Set(THY_BEGIN)
d887abcc7c24 more command categories, as in ML;
wenzelm
parents: 59122
diff changeset
    62
  val theory_end = Set(THY_END)
d887abcc7c24 more command categories, as in ML;
wenzelm
parents: 59122
diff changeset
    63
59701
8ab877c91992 more command categories, as in ML;
wenzelm
parents: 59700
diff changeset
    64
  val theory_load = Set(THY_LOAD)
8ab877c91992 more command categories, as in ML;
wenzelm
parents: 59700
diff changeset
    65
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    66
  val theory =
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    67
    Set(THY_BEGIN, THY_END, THY_LOAD, THY_DECL, THY_DECL_BLOCK, THY_DEFN, THY_STMT,
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    68
      THY_GOAL, THY_GOAL_DEFN, THY_GOAL_STMT)
57837
63e3c45b85e1 removed unused stuff;
wenzelm
parents: 57836
diff changeset
    69
58800
bfed1c26caed explicit keyword category for commands that may start a block;
wenzelm
parents: 57837
diff changeset
    70
  val theory_block = Set(THY_BEGIN, THY_DECL_BLOCK)
bfed1c26caed explicit keyword category for commands that may start a block;
wenzelm
parents: 57837
diff changeset
    71
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    72
  val theory_body =
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    73
    Set(THY_LOAD, THY_DECL, THY_DECL_BLOCK, THY_DEFN, THY_STMT,
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    74
      THY_GOAL, THY_GOAL_DEFN, THY_GOAL_STMT)
57835
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    75
69917
66c4567664b5 tuned signature;
wenzelm
parents: 69913
diff changeset
    76
  val theory_defn = Set(THY_DEFN, THY_GOAL_DEFN)
66c4567664b5 tuned signature;
wenzelm
parents: 69913
diff changeset
    77
63479
wenzelm
parents: 63441
diff changeset
    78
  val prf_script = Set(PRF_SCRIPT)
wenzelm
parents: 63441
diff changeset
    79
40456
e91b3c2145b4 added missing Keyword.THY_SCHEMATIC_GOAL;
wenzelm
parents: 38236
diff changeset
    80
  val proof =
60694
b3fa4a8cdb5f clarified text folds: proof ... qed counts as extra block;
wenzelm
parents: 60692
diff changeset
    81
    Set(QED, QED_SCRIPT, QED_BLOCK, QED_GLOBAL, PRF_GOAL, PRF_BLOCK, NEXT_BLOCK, PRF_OPEN,
b3fa4a8cdb5f clarified text folds: proof ... qed counts as extra block;
wenzelm
parents: 60692
diff changeset
    82
      PRF_CLOSE, PRF_CHAIN, PRF_DECL, PRF_ASM, PRF_ASM_GOAL, PRF_SCRIPT, PRF_SCRIPT_GOAL,
60624
5b6552e12421 clarified keyword categories;
wenzelm
parents: 59701
diff changeset
    83
      PRF_SCRIPT_ASM_GOAL)
57835
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    84
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    85
  val proof_body =
60694
b3fa4a8cdb5f clarified text folds: proof ... qed counts as extra block;
wenzelm
parents: 60692
diff changeset
    86
    Set(DIAG, DOCUMENT_HEADING, DOCUMENT_BODY, DOCUMENT_RAW, PRF_BLOCK, NEXT_BLOCK, PRF_OPEN,
b3fa4a8cdb5f clarified text folds: proof ... qed counts as extra block;
wenzelm
parents: 60692
diff changeset
    87
      PRF_CLOSE, PRF_CHAIN, PRF_DECL, PRF_ASM, PRF_ASM_GOAL, PRF_SCRIPT, PRF_SCRIPT_GOAL,
60624
5b6552e12421 clarified keyword categories;
wenzelm
parents: 59701
diff changeset
    88
      PRF_SCRIPT_ASM_GOAL)
57835
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    89
72669
5e7916535860 generate theory HTML in Isabelle/Scala;
wenzelm
parents: 71601
diff changeset
    90
  val proof_asm = Set(PRF_ASM, PRF_ASM_GOAL)
5e7916535860 generate theory HTML in Isabelle/Scala;
wenzelm
parents: 71601
diff changeset
    91
  val improper = Set(QED_SCRIPT, PRF_SCRIPT, PRF_SCRIPT_GOAL, PRF_SCRIPT_ASM_GOAL)
5e7916535860 generate theory HTML in Isabelle/Scala;
wenzelm
parents: 71601
diff changeset
    92
69913
ca515cf61651 more specific keyword kinds;
wenzelm
parents: 67090
diff changeset
    93
  val theory_goal = Set(THY_GOAL, THY_GOAL_DEFN, THY_GOAL_STMT)
60624
5b6552e12421 clarified keyword categories;
wenzelm
parents: 59701
diff changeset
    94
  val proof_goal = Set(PRF_GOAL, PRF_ASM_GOAL, PRF_SCRIPT_GOAL, PRF_SCRIPT_ASM_GOAL)
57835
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    95
  val qed = Set(QED, QED_SCRIPT, QED_BLOCK)
43ff8638c02c more keyword categories (as in ML);
wenzelm
parents: 56146
diff changeset
    96
  val qed_global = Set(QED_GLOBAL)
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
    97
60692
wenzelm
parents: 60624
diff changeset
    98
  val proof_open = proof_goal + PRF_OPEN
wenzelm
parents: 60624
diff changeset
    99
  val proof_close = qed + PRF_CLOSE
63428
005b490f0ce2 indentation in reminiscence to Proof General (see proof-indent.el);
wenzelm
parents: 63424
diff changeset
   100
  val proof_enclose = Set(PRF_BLOCK, NEXT_BLOCK, QED_BLOCK, PRF_CLOSE)
60692
wenzelm
parents: 60624
diff changeset
   101
63603
9d9ea2c6bc38 clarified modules;
wenzelm
parents: 63579
diff changeset
   102
  val close_structure = Set(NEXT_BLOCK, QED_BLOCK, PRF_CLOSE, THY_END)
9d9ea2c6bc38 clarified modules;
wenzelm
parents: 63579
diff changeset
   103
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   104
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   105
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   106
  /** keyword tables **/
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   107
72764
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   108
  sealed case class Spec(
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   109
    kind: String = "",
72765
f34f5c057c9e clarified parsing vs. semantic errors;
wenzelm
parents: 72764
diff changeset
   110
    kind_pos: Position.T = Position.none,
72764
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   111
    load_command: String = "",
72765
f34f5c057c9e clarified parsing vs. semantic errors;
wenzelm
parents: 72764
diff changeset
   112
    load_command_pos: Position.T = Position.none,
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   113
    tags: List[String] = Nil
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   114
  ) {
65385
23f36ab9042b print like syntax of Thy_Header.header;
wenzelm
parents: 65384
diff changeset
   115
    override def toString: String =
23f36ab9042b print like syntax of Thy_Header.header;
wenzelm
parents: 65384
diff changeset
   116
      kind +
77368
wenzelm
parents: 75393
diff changeset
   117
        if_proper(load_command, " (" + quote(load_command) + ")") +
wenzelm
parents: 75393
diff changeset
   118
        if_proper(tags, tags.map(quote).mkString(" % ", " % ", ""))
72764
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   119
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   120
    def map(f: String => String): Spec =
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   121
      copy(kind = f(kind), load_command = f(load_command), tags = tags.map(f))
65384
36255c43c64c more explicit types;
wenzelm
parents: 63809
diff changeset
   122
  }
63429
baedd4724f08 tuned signature: more uniform Keyword.spec;
wenzelm
parents: 63428
diff changeset
   123
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   124
  object Keywords {
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   125
    def empty: Keywords = new Keywords()
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   126
  }
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   127
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   128
  class Keywords private(
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   129
    val kinds: Map[String, String] = Map.empty,
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   130
    val load_commands: Map[String, String] = Map.empty
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   131
  ) {
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   132
    override def toString: String = {
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   133
      val entries =
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   134
        for ((name, kind) <- kinds.toList.sortBy(_._1)) yield {
72748
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   135
          val load_decl =
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   136
            load_commands.get(name) match {
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   137
              case Some(load_command) => " (" + quote(load_command) + ")"
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   138
              case None => ""
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   139
            }
77368
wenzelm
parents: 75393
diff changeset
   140
          val kind_decl = if_proper(kind, " :: " + quote(kind) + load_decl)
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   141
          quote(name) + kind_decl
63430
9c5fcd355a2d support for quasi_command keywords;
wenzelm
parents: 63429
diff changeset
   142
        }
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   143
      entries.mkString("keywords\n  ", " and\n  ", "")
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   144
    }
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   145
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   146
59073
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   147
    /* merge */
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   148
67090
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   149
    def is_empty: Boolean = kinds.isEmpty
59073
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   150
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   151
    def ++ (other: Keywords): Keywords =
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   152
      if (this eq other) this
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   153
      else if (is_empty) other
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   154
      else {
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   155
        val kinds1 =
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   156
          if (kinds eq other.kinds) kinds
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   157
          else if (kinds.isEmpty) other.kinds
73359
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   158
          else other.kinds.foldLeft(kinds) { case (m, e) => if (m.isDefinedAt(e._1)) m else m + e }
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   159
        val load_commands1 =
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   160
          if (load_commands eq other.load_commands) load_commands
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   161
          else if (load_commands.isEmpty) other.load_commands
73359
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   162
          else {
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   163
            other.load_commands.foldLeft(load_commands) {
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   164
              case (m, e) => if (m.isDefinedAt(e._1)) m else m + e
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   165
            }
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   166
          }
67090
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   167
        new Keywords(kinds1, load_commands1)
59073
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   168
      }
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   169
dcecfcc56dce more merge operations;
wenzelm
parents: 58999
diff changeset
   170
58902
wenzelm
parents: 58901
diff changeset
   171
    /* add keywords */
wenzelm
parents: 58901
diff changeset
   172
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   173
    def + (name: String, kind: String = "", load_command: String = ""): Keywords = {
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   174
      val kinds1 = kinds + (name -> kind)
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   175
      val load_commands1 =
66919
1f93e376aeb6 more explicit check;
wenzelm
parents: 65385
diff changeset
   176
        if (kind == THY_LOAD) {
71601
97ccf48c2f0c misc tuning based on hints by IntelliJ IDEA;
wenzelm
parents: 70123
diff changeset
   177
          if (!Symbol.iterator(name).forall(Symbol.is_ascii))
66919
1f93e376aeb6 more explicit check;
wenzelm
parents: 65385
diff changeset
   178
            error("Bad theory load command " + quote(name))
72748
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   179
          load_commands + (name -> load_command)
66919
1f93e376aeb6 more explicit check;
wenzelm
parents: 65385
diff changeset
   180
        }
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   181
        else load_commands
67090
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   182
      new Keywords(kinds1, load_commands1)
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   183
    }
58902
wenzelm
parents: 58901
diff changeset
   184
58928
23d0ffd48006 plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
wenzelm
parents: 58907
diff changeset
   185
    def add_keywords(header: Thy_Header.Keywords): Keywords =
73359
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   186
      header.foldLeft(this) {
65384
36255c43c64c more explicit types;
wenzelm
parents: 63809
diff changeset
   187
        case (keywords, (name, spec)) =>
72764
722c0d02ffab clarified signature;
wenzelm
parents: 72748
diff changeset
   188
          if (spec.kind.isEmpty)
65384
36255c43c64c more explicit types;
wenzelm
parents: 63809
diff changeset
   189
            keywords + Symbol.decode(name) + Symbol.encode(name)
36255c43c64c more explicit types;
wenzelm
parents: 63809
diff changeset
   190
          else
36255c43c64c more explicit types;
wenzelm
parents: 63809
diff changeset
   191
            keywords +
72748
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   192
              (Symbol.decode(name), spec.kind, spec.load_command) +
04d5f6d769a7 more flexible syntax for theory load commands via Isabelle/Scala;
wenzelm
parents: 72740
diff changeset
   193
              (Symbol.encode(name), spec.kind, spec.load_command)
58928
23d0ffd48006 plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
wenzelm
parents: 58907
diff changeset
   194
      }
23d0ffd48006 plain value Keywords.keywords, which might be used outside theory for bootstrap purposes;
wenzelm
parents: 58907
diff changeset
   195
58902
wenzelm
parents: 58901
diff changeset
   196
58901
47809a811eba clarified representation of type Keywords;
wenzelm
parents: 58900
diff changeset
   197
    /* command kind */
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   198
63424
e4e15bbfb3e2 clarified signature;
wenzelm
parents: 60694
diff changeset
   199
    def is_command(token: Token, check_kind: String => Boolean): Boolean =
e4e15bbfb3e2 clarified signature;
wenzelm
parents: 60694
diff changeset
   200
      token.is_command &&
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   201
        (kinds.get(token.source) match { case Some(k) => check_kind(k) case None => false })
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   202
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   203
    def is_before_command(token: Token): Boolean =
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   204
      token.is_keyword && kinds.get(token.source) == Some(BEFORE_COMMAND)
59701
8ab877c91992 more command categories, as in ML;
wenzelm
parents: 59700
diff changeset
   205
63430
9c5fcd355a2d support for quasi_command keywords;
wenzelm
parents: 63429
diff changeset
   206
    def is_quasi_command(token: Token): Boolean =
63441
4c3fa4dba79f explicit kind "before_command";
wenzelm
parents: 63430
diff changeset
   207
      token.is_keyword && kinds.get(token.source) == Some(QUASI_COMMAND)
63430
9c5fcd355a2d support for quasi_command keywords;
wenzelm
parents: 63429
diff changeset
   208
63809
wenzelm
parents: 63603
diff changeset
   209
    def is_indent_command(token: Token): Boolean =
wenzelm
parents: 63603
diff changeset
   210
      token.is_begin_or_command || is_quasi_command(token)
wenzelm
parents: 63603
diff changeset
   211
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   212
67090
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   213
    /* lexicons */
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   214
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   215
    private def make_lexicon(is_minor: Boolean): Scan.Lexicon =
73359
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   216
      kinds.foldLeft(Scan.Lexicon.empty) {
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   217
        case (lex, (name, kind)) =>
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   218
          if ((kind == "" || kind == BEFORE_COMMAND || kind == QUASI_COMMAND) == is_minor)
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   219
            lex + name
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   220
          else lex
d8a0e996614b tuned --- fewer warnings;
wenzelm
parents: 72765
diff changeset
   221
      }
67090
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   222
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   223
    lazy val minor: Scan.Lexicon = make_lexicon(true)
0ec94bb9cec4 clarified lazy lexicons within Keywords: measurable speedup of Sessions.deps;
wenzelm
parents: 66919
diff changeset
   224
    lazy val major: Scan.Lexicon = make_lexicon(false)
58900
1435cc20b022 explicit type Keyword.Keywords;
wenzelm
parents: 58868
diff changeset
   225
  }
29449
6e7745d35a30 added outer_keyword.scala: Isar command keyword classification;
wenzelm
parents:
diff changeset
   226
}