src/Pure/Isar/document_structure.scala
author wenzelm
Sat, 15 Apr 2023 14:14:30 +0200
changeset 77855 ff801186ff66
parent 76914 1bc50ffad6d2
child 78912 ff4496b25197
permissions -rw-r--r--
minor performance tuning: more elementary operations;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Isar/document_structure.scala
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     3
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     4
Overall document structure.
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     5
*/
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     6
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     7
package isabelle
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     8
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
     9
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    10
import scala.collection.mutable
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    11
import scala.annotation.tailrec
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    12
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    13
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    14
object Document_Structure {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
    15
  /** general structure **/
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    16
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    17
  sealed abstract class Document { def length: Int }
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    18
  case class Block(name: String, text: String, body: List[Document]) extends Document {
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    19
    val length: Int = body.foldLeft(0)(_ + _.length)
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    20
  }
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
    21
  case class Atom(length: Int) extends Document
63605
wenzelm
parents: 63604
diff changeset
    22
69859
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    23
  def is_theory_command(keywords: Keyword.Keywords, command: Command): Boolean =
68845
3b2daa7bf9f4 support Thy_Element in Scala, following ML version;
wenzelm
parents: 68840
diff changeset
    24
    command.span.is_kind(keywords,
3b2daa7bf9f4 support Thy_Element in Scala, following ML version;
wenzelm
parents: 68840
diff changeset
    25
      kind => Keyword.theory(kind) && !Keyword.theory_end(kind), false)
63605
wenzelm
parents: 63604
diff changeset
    26
70148
73a34cb9e67e tuned signature: more operations;
wenzelm
parents: 69869
diff changeset
    27
  def is_document_command(keywords: Keyword.Keywords, command: Command): Boolean =
73a34cb9e67e tuned signature: more operations;
wenzelm
parents: 69869
diff changeset
    28
    command.span.is_kind(keywords, Keyword.document, false)
73a34cb9e67e tuned signature: more operations;
wenzelm
parents: 69869
diff changeset
    29
71165
03afc8252225 support for output messages;
wenzelm
parents: 70148
diff changeset
    30
  def is_diag_command(keywords: Keyword.Keywords, command: Command): Boolean =
03afc8252225 support for output messages;
wenzelm
parents: 70148
diff changeset
    31
    command.span.is_kind(keywords, Keyword.diag, false)
03afc8252225 support for output messages;
wenzelm
parents: 70148
diff changeset
    32
69869
f2c3512df446 tuned signature;
wenzelm
parents: 69860
diff changeset
    33
  def is_heading_command(command: Command): Boolean =
f2c3512df446 tuned signature;
wenzelm
parents: 69860
diff changeset
    34
    proper_heading_level(command).isDefined
f2c3512df446 tuned signature;
wenzelm
parents: 69860
diff changeset
    35
69860
b58a575d211e tuned signature;
wenzelm
parents: 69859
diff changeset
    36
  def proper_heading_level(command: Command): Option[Int] =
69859
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    37
    command.span.name match {
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    38
      case Thy_Header.CHAPTER => Some(0)
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    39
      case Thy_Header.SECTION => Some(1)
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    40
      case Thy_Header.SUBSECTION => Some(2)
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    41
      case Thy_Header.SUBSUBSECTION => Some(3)
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    42
      case Thy_Header.PARAGRAPH => Some(4)
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    43
      case Thy_Header.SUBPARAGRAPH => Some(5)
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    44
      case _ => None
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    45
    }
69860
b58a575d211e tuned signature;
wenzelm
parents: 69859
diff changeset
    46
b58a575d211e tuned signature;
wenzelm
parents: 69859
diff changeset
    47
  def heading_level(keywords: Keyword.Keywords, command: Command): Option[Int] =
b58a575d211e tuned signature;
wenzelm
parents: 69859
diff changeset
    48
    proper_heading_level(command) orElse
b58a575d211e tuned signature;
wenzelm
parents: 69859
diff changeset
    49
      (if (is_theory_command(keywords, command)) Some(6) else None)
69859
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
    50
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
    51
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    52
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
    53
  /** context blocks **/
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    54
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    55
  def parse_blocks(
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    56
    syntax: Outer_Syntax,
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    57
    node_name: Document.Node.Name,
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    58
    text: CharSequence
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    59
  ): List[Document] = {
63607
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    60
    def is_plain_theory(command: Command): Boolean =
68840
51ab4c78235b tuned signature;
wenzelm
parents: 64610
diff changeset
    61
      is_theory_command(syntax.keywords, command) &&
63607
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    62
      !command.span.is_begin && !command.span.is_end
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    63
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    64
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    65
    /* stack operations */
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    66
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    67
    def buffer(): mutable.ListBuffer[Document] = new mutable.ListBuffer[Document]
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    68
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    69
    var stack: List[(Command, mutable.ListBuffer[Document])] =
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    70
      List((Command.empty, buffer()))
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    71
73340
0ffcad1f6130 tuned --- fewer warnings;
wenzelm
parents: 72814
diff changeset
    72
    def open(command: Command): Unit = { stack = (command, buffer()) :: stack }
63607
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    73
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    74
    def close(): Boolean =
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    75
      stack match {
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    76
        case (command, body) :: (_, body2) :: _ =>
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    77
          body2 += Block(command.span.name, command.source, body.toList)
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    78
          stack = stack.tail
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    79
          true
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    80
        case _ =>
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    81
          false
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    82
      }
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    83
73340
0ffcad1f6130 tuned --- fewer warnings;
wenzelm
parents: 72814
diff changeset
    84
    def flush(): Unit = if (is_plain_theory(stack.head._1)) close()
63607
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    85
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    86
    def result(): List[Document] = {
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    87
      while (close()) { }
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    88
      stack.head._2.toList
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    89
    }
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    90
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
    91
    def add(command: Command): Unit = {
63607
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    92
      if (command.span.is_begin || is_plain_theory(command)) { flush(); open(command) }
7246254d558f clarified handling of plain theory commands;
wenzelm
parents: 63606
diff changeset
    93
      else if (command.span.is_end) { flush(); close() }
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    94
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
    95
      stack.head._2 += Atom(command.source.length)
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    96
    }
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    97
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    98
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
    99
    /* result structure */
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   100
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   101
    val spans = syntax.parse_spans(text)
76914
1bc50ffad6d2 tuned signature;
wenzelm
parents: 75393
diff changeset
   102
    spans.foreach(span => add(Command(Document_ID.none, node_name, Command.Blobs_Info.empty, span)))
63606
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   103
    result()
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   104
  }
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   105
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   106
fc3a23763617 support for context block structure in Sidekick;
wenzelm
parents: 63605
diff changeset
   107
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   108
  /** section headings **/
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   109
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   110
  trait Item {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   111
    def name: String = ""
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   112
    def source: String = ""
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   113
    def heading_level: Option[Int] = None
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   114
  }
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   115
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   116
  object No_Item extends Item
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   117
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   118
  class Sections(keywords: Keyword.Keywords) {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   119
    private def buffer(): mutable.ListBuffer[Document] = new mutable.ListBuffer[Document]
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   120
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   121
    private var stack: List[(Int, Item, mutable.ListBuffer[Document])] =
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   122
      List((0, No_Item, buffer()))
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   123
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   124
    @tailrec private def close(level: Int => Boolean): Unit = {
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   125
      stack match {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   126
        case (lev, item, body) :: (_, _, body2) :: _ if level(lev) =>
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   127
          body2 += Block(item.name, item.source, body.toList)
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   128
          stack = stack.tail
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   129
          close(level)
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   130
        case _ =>
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   131
      }
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   132
    }
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   133
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   134
    def result(): List[Document] = {
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   135
      close(_ => true)
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   136
      stack.head._3.toList
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   137
    }
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   138
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   139
    def add(item: Item): Unit = {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   140
      item.heading_level match {
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   141
        case Some(i) =>
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   142
          close(_ > i)
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   143
          stack = (i + 1, item, buffer()) :: stack
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   144
        case None =>
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   145
      }
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   146
      stack.head._3 += Atom(item.source.length)
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   147
    }
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   148
  }
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   149
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   150
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   151
  /* outer syntax sections */
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   152
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   153
  private class Command_Item(keywords: Keyword.Keywords, command: Command) extends Item {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   154
    override def name: String = command.span.name
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   155
    override def source: String = command.source
69859
e18ba60a1cf8 clarified signature -- allow more re-use;
wenzelm
parents: 68845
diff changeset
   156
    override def heading_level: Option[Int] = Document_Structure.heading_level(keywords, command)
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   157
  }
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   158
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   159
  def parse_sections(
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   160
    syntax: Outer_Syntax,
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   161
    node_name: Document.Node.Name,
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   162
    text: CharSequence
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   163
  ): List[Document] = {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   164
    val sections = new Sections(syntax.keywords)
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   165
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   166
    for { span <- syntax.parse_spans(text) } {
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   167
      sections.add(
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   168
        new Command_Item(syntax.keywords,
76914
1bc50ffad6d2 tuned signature;
wenzelm
parents: 75393
diff changeset
   169
          Command(Document_ID.none, node_name, Command.Blobs_Info.empty, span)))
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   170
    }
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   171
    sections.result()
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   172
  }
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   173
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   174
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   175
  /* ML sections */
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   176
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   177
  private class ML_Item(token: ML_Lex.Token, level: Option[Int]) extends Item {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   178
    override def source: String = token.source
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   179
    override def heading_level: Option[Int] = level
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   180
  }
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   181
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   182
  def parse_ml_sections(SML: Boolean, text: CharSequence): List[Document] = {
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   183
    val sections = new Sections(Keyword.Keywords.empty)
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   184
    val nl = new ML_Item(ML_Lex.Token(ML_Lex.Kind.SPACE, "\n"), None)
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   185
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   186
    var context: Scan.Line_Context = Scan.Finished
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   187
    for (line <- Library.separated_chunks(_ == '\n', text)) {
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   188
      val (toks, next_context) = ML_Lex.tokenize_line(SML, line, context)
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   189
      val level =
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   190
        toks.filterNot(_.is_space) match {
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   191
          case List(tok) if tok.is_comment =>
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   192
            val s = tok.source
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73359
diff changeset
   193
            if (Codepoint.iterator(s).exists(c => Character.isLetter(c) || Character.isDigit(c))) {
63666
ff6caffcaed4 suppress ASCII art;
wenzelm
parents: 63610
diff changeset
   194
              if (s.startsWith("(**** ") && s.endsWith(" ****)")) Some(0)
ff6caffcaed4 suppress ASCII art;
wenzelm
parents: 63610
diff changeset
   195
              else if (s.startsWith("(*** ") && s.endsWith(" ***)")) Some(1)
ff6caffcaed4 suppress ASCII art;
wenzelm
parents: 63610
diff changeset
   196
              else if (s.startsWith("(** ") && s.endsWith(" **)")) Some(2)
ff6caffcaed4 suppress ASCII art;
wenzelm
parents: 63610
diff changeset
   197
              else if (s.startsWith("(* ") && s.endsWith(" *)")) Some(3)
ff6caffcaed4 suppress ASCII art;
wenzelm
parents: 63610
diff changeset
   198
              else None
ff6caffcaed4 suppress ASCII art;
wenzelm
parents: 63610
diff changeset
   199
            }
63610
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   200
            else None
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   201
          case _ => None
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   202
        }
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   203
      if (level.isDefined && context == Scan.Finished && next_context == Scan.Finished)
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   204
        toks.foreach(tok => sections.add(new ML_Item(tok, if (tok.is_comment) level else None)))
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   205
      else
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   206
        toks.foreach(tok => sections.add(new ML_Item(tok, None)))
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   207
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   208
      sections.add(nl)
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   209
      context = next_context
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   210
    }
4b40b8196dc7 Sidekick parser for isabelle-ml and sml mode;
wenzelm
parents: 63607
diff changeset
   211
    sections.result()
63604
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   212
  }
d8de4f8b95eb clarified modules;
wenzelm
parents:
diff changeset
   213
}