| 56800 |      1 | /*  Title:      Pure/General/long_name.scala
 | 
|  |      2 |     Author:     Makarius
 | 
|  |      3 | 
 | 
|  |      4 | Long names.
 | 
|  |      5 | */
 | 
|  |      6 | 
 | 
|  |      7 | package isabelle
 | 
|  |      8 | 
 | 
|  |      9 | 
 | 
| 75393 |     10 | object Long_Name {
 | 
| 56800 |     11 |   val separator = "."
 | 
|  |     12 |   val separator_char = '.'
 | 
|  |     13 | 
 | 
|  |     14 |   def is_qualified(name: String): Boolean = name.contains(separator_char)
 | 
|  |     15 | 
 | 
|  |     16 |   def implode(names: List[String]): String = names.mkString(separator)
 | 
| 66923 |     17 |   def explode(name: String): List[String] = space_explode(separator_char, name)
 | 
| 56800 |     18 | 
 | 
|  |     19 |   def qualify(qual: String, name: String): String =
 | 
|  |     20 |     if (qual == "" || name == "") name
 | 
|  |     21 |     else qual + separator + name
 | 
|  |     22 | 
 | 
| 65440 |     23 |   def qualifier(name: String): String =
 | 
|  |     24 |     if (name == "") ""
 | 
|  |     25 |     else implode(explode(name).dropRight(1))
 | 
|  |     26 | 
 | 
| 56800 |     27 |   def base_name(name: String): String =
 | 
|  |     28 |     if (name == "") ""
 | 
|  |     29 |     else explode(name).last
 | 
| 78961 |     30 | 
 | 
|  |     31 |   def try_unqualify(qual: String, name: String): Option[String] = {
 | 
|  |     32 |     val m = qual.length
 | 
|  |     33 |     val n = name.length
 | 
|  |     34 |     if (0 < m && m < n && name.startsWith(qual) && name(m) == separator_char)
 | 
|  |     35 |       Some(name.substring(m + 1))
 | 
|  |     36 |     else None
 | 
|  |     37 |   }
 | 
| 56800 |     38 | }
 |