src/Pure/GUI/rich_text.scala
author wenzelm
Tue, 12 Nov 2024 11:32:07 +0100
changeset 81432 85fc3b482924
parent 81428 257ec066b360
child 81433 c3793899b880
permissions -rw-r--r--
clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
81416
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/GUI/rich_text.scala
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     3
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     4
Support for rendering of rich text, based on individual messages (XML.Elem).
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     5
*/
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     6
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     7
package isabelle
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     8
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
     9
81417
964b85e04f1f clarified margin operations (again, reverting 4794576828df);
wenzelm
parents: 81416
diff changeset
    10
import javax.swing.JComponent
964b85e04f1f clarified margin operations (again, reverting 4794576828df);
wenzelm
parents: 81416
diff changeset
    11
81418
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    12
import scala.collection.mutable
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    13
81417
964b85e04f1f clarified margin operations (again, reverting 4794576828df);
wenzelm
parents: 81416
diff changeset
    14
81416
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
    15
object Rich_Text {
81420
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    16
  /* margin */
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    17
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    18
  def make_margin(metric: Font_Metric, margin: Int, limit: Int = -1): Int = {
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    19
    val m = (margin * metric.average).toInt
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    20
    (if (limit < 0) m else m min limit) max 20
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    21
  }
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    22
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    23
  def component_margin(metric: Font_Metric, component: JComponent): Int =
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    24
    make_margin(metric, (component.getWidth.toDouble / metric.average_width).toInt)
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    25
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    26
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    27
  /* format */
d25a241502c1 tuned comments;
wenzelm
parents: 81419
diff changeset
    28
81432
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    29
  sealed case class Formatted(id: Document_ID.Generic, body: XML.Body) {
81421
8c1680ac4160 clarified signature and data storage: incremental lazy values;
wenzelm
parents: 81420
diff changeset
    30
    lazy val text: String = XML.content(body)
81432
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    31
    lazy val markups: Command.Markups = Command.Markups.init(Markup_Tree.from_XML(body))
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    32
    def command(results: Command.Results): Command =
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    33
      Command.unparsed(text, id = id, results = results, markups = markups)
81416
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
    34
  }
81417
964b85e04f1f clarified margin operations (again, reverting 4794576828df);
wenzelm
parents: 81416
diff changeset
    35
81432
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    36
  def format(msgs: List[XML.Elem], margin: Double, metric: Font_Metric): List[Formatted] = {
81421
8c1680ac4160 clarified signature and data storage: incremental lazy values;
wenzelm
parents: 81420
diff changeset
    37
    val result = new mutable.ListBuffer[Formatted]
81418
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    38
    for (msg <- msgs) {
81432
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    39
      if (result.nonEmpty) result += Formatted(Document_ID.make(), Pretty.Separator)
81421
8c1680ac4160 clarified signature and data storage: incremental lazy values;
wenzelm
parents: 81420
diff changeset
    40
8c1680ac4160 clarified signature and data storage: incremental lazy values;
wenzelm
parents: 81420
diff changeset
    41
      val id = Protocol_Message.get_serial(msg)
81418
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    42
      val body = Pretty.formatted(List(msg), margin = margin, metric = metric)
81432
85fc3b482924 clarified persistent values: Command.Results does not suitable for caching, because it contains all other messages;
wenzelm
parents: 81428
diff changeset
    43
      result += Formatted(id, body)
81418
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    44
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    45
      Exn.Interrupt.expose()
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    46
    }
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    47
    result.toList
de8dbdadda76 clarified modules;
wenzelm
parents: 81417
diff changeset
    48
  }
81428
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    49
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    50
  def formatted_lines(formatted: List[Formatted]): Int =
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    51
    if (formatted.isEmpty) 0
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    52
    else {
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    53
      1 + formatted.iterator.map(form =>
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    54
        XML.traverse_text(form.body, 0, (n, s) => n + Library.count_newlines(s))).sum
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    55
    }
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    56
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    57
  def formatted_margin(metric: Font_Metric, formatted: List[Formatted]): Double =
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    58
    split_lines(formatted.map(_.text).mkString)
257ec066b360 clarified signature and modules;
wenzelm
parents: 81424
diff changeset
    59
      .foldLeft(0.0) { case (m, line) => m max metric(line) }
81416
206dd586f3d7 clarified modules;
wenzelm
parents:
diff changeset
    60
}