src/Pure/General/long_name.scala
author wenzelm
Sun, 21 Jul 2024 13:44:05 +0200
changeset 80604 67067490392d
parent 78961 11045cf2b5c2
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56800
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/General/long_name.scala
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     3
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     4
Long names.
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     5
*/
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     6
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     7
package isabelle
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     8
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
     9
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 66923
diff changeset
    10
object Long_Name {
56800
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    11
  val separator = "."
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    12
  val separator_char = '.'
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    13
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    14
  def is_qualified(name: String): Boolean = name.contains(separator_char)
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    15
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    16
  def implode(names: List[String]): String = names.mkString(separator)
66923
wenzelm
parents: 65440
diff changeset
    17
  def explode(name: String): List[String] = space_explode(separator_char, name)
56800
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    18
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    19
  def qualify(qual: String, name: String): String =
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    20
    if (qual == "" || name == "") name
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    21
    else qual + separator + name
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    22
65440
fd147f56d9be more operations;
wenzelm
parents: 65358
diff changeset
    23
  def qualifier(name: String): String =
fd147f56d9be more operations;
wenzelm
parents: 65358
diff changeset
    24
    if (name == "") ""
fd147f56d9be more operations;
wenzelm
parents: 65358
diff changeset
    25
    else implode(explode(name).dropRight(1))
fd147f56d9be more operations;
wenzelm
parents: 65358
diff changeset
    26
56800
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    27
  def base_name(name: String): String =
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    28
    if (name == "") ""
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    29
    else explode(name).last
78961
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    30
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    31
  def try_unqualify(qual: String, name: String): Option[String] = {
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    32
    val m = qual.length
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    33
    val n = name.length
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    34
    if (0 < m && m < n && name.startsWith(qual) && name(m) == separator_char)
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    35
      Some(name.substring(m + 1))
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    36
    else None
11045cf2b5c2 tuned signature: more operations;
wenzelm
parents: 75393
diff changeset
    37
  }
56800
b904ea8edd73 support for long names in Scala;
wenzelm
parents:
diff changeset
    38
}