src/Pure/thm_name.scala
author wenzelm
Wed, 14 Aug 2024 18:59:49 +0200
changeset 80708 3f2c371a3de9
parent 80312 b48768f9567f
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
70576
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/thm_name.scala
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     3
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     4
Systematic naming of individual theorems, as selections from multi-facts.
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     5
*/
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     6
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     7
package isabelle
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     8
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
     9
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    10
import scala.math.Ordering
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    11
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    12
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 70580
diff changeset
    13
object Thm_Name {
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 70580
diff changeset
    14
  object Ordering extends scala.math.Ordering[Thm_Name] {
70576
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    15
    def compare(thm_name1: Thm_Name, thm_name2: Thm_Name): Int =
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    16
      thm_name1.name compare thm_name2.name match {
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    17
        case 0 => thm_name1.index compare thm_name2.index
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    18
        case ord => ord
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    19
      }
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    20
  }
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    21
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    22
  def graph[A]: Graph[Thm_Name, A] = Graph.empty(Ordering)
70580
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    23
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    24
  private val Thm_Name_Regex = """^(.)+\((\d+)\)$""".r
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    25
80295
8a9588ffc133 more accurate Thm_Name.T for PThm / Thm.name_derivation / Thm.derivation_name;
wenzelm
parents: 79376
diff changeset
    26
  val empty: Thm_Name = Thm_Name("", 0)
8a9588ffc133 more accurate Thm_Name.T for PThm / Thm.name_derivation / Thm.derivation_name;
wenzelm
parents: 79376
diff changeset
    27
70580
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    28
  def parse(s: String): Thm_Name =
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    29
    s match {
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    30
      case Thm_Name_Regex(name, Value.Nat(index)) => Thm_Name(name, index)
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    31
      case _ => Thm_Name(s, 0)
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    32
    }
80312
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    33
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    34
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    35
  /* XML data representation */
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    36
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    37
  def encode: XML.Encode.T[Thm_Name] = { (thm_name: Thm_Name) =>
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    38
    import XML.Encode._
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    39
    pair(string, int)((thm_name.name, thm_name.index))
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    40
  }
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    41
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    42
  def decode: XML.Decode.T[Thm_Name] = { (body: XML.Body) =>
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    43
    import XML.Decode._
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    44
    val (name, index) = pair(string, int)(body)
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    45
    Thm_Name(name, index)
b48768f9567f more operations, following Isabelle/ML;
wenzelm
parents: 80295
diff changeset
    46
  }
70576
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    47
}
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    48
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 70580
diff changeset
    49
sealed case class Thm_Name(name: String, index: Int) {
80295
8a9588ffc133 more accurate Thm_Name.T for PThm / Thm.name_derivation / Thm.derivation_name;
wenzelm
parents: 79376
diff changeset
    50
  def is_empty: Boolean = name.isEmpty
8a9588ffc133 more accurate Thm_Name.T for PThm / Thm.name_derivation / Thm.derivation_name;
wenzelm
parents: 79376
diff changeset
    51
70580
e6101f131d0d clarified signature;
wenzelm
parents: 70576
diff changeset
    52
  def print: String =
70576
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    53
    if (name == "" || index == 0) name
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    54
    else name + "(" + index + ")"
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    55
79376
b275e3379024 tuned signature;
wenzelm
parents: 75393
diff changeset
    56
  def short: String =
70576
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    57
    if (name == "" || index == 0) name
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    58
    else name + "_" + index
3554531505a8 module Thm_Name for Isabelle/Scala;
wenzelm
parents:
diff changeset
    59
}