src/Pure/General/position.scala
author wenzelm
Fri, 20 Jul 2012 22:29:25 +0200
changeset 48409 0d2114eb412a
parent 48370 d0fa3efec93b
child 48548 49afe0e92163
permissions -rw-r--r--
more explicit java.io.{File => JFile};
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27968
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/General/position.scala
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     3
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     4
Position properties.
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     5
*/
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     6
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     7
package isabelle
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     8
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
     9
48409
0d2114eb412a more explicit java.io.{File => JFile};
wenzelm
parents: 48370
diff changeset
    10
import java.io.{File => JFile}
0d2114eb412a more explicit java.io.{File => JFile};
wenzelm
parents: 48370
diff changeset
    11
0d2114eb412a more explicit java.io.{File => JFile};
wenzelm
parents: 48370
diff changeset
    12
32450
375db037f4d2 misc tuning;
wenzelm
parents: 31705
diff changeset
    13
object Position
375db037f4d2 misc tuning;
wenzelm
parents: 31705
diff changeset
    14
{
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 43710
diff changeset
    15
  type T = Properties.T
27968
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
    16
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    17
  val Line = new Properties.Int(Isabelle_Markup.LINE)
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    18
  val Offset = new Properties.Int(Isabelle_Markup.OFFSET)
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    19
  val End_Offset = new Properties.Int(Isabelle_Markup.END_OFFSET)
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    20
  val File = new Properties.String(Isabelle_Markup.FILE)
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    21
  val Id = new Properties.Long(Isabelle_Markup.ID)
31705
0c83e3e75fcf replaced java Properties by pure property lists;
wenzelm
parents: 29140
diff changeset
    22
48409
0d2114eb412a more explicit java.io.{File => JFile};
wenzelm
parents: 48370
diff changeset
    23
  def file(f: JFile): T = File(Isabelle_System.posix_path(f.toString))
0d2114eb412a more explicit java.io.{File => JFile};
wenzelm
parents: 48370
diff changeset
    24
  def line_file(i: Int, f: JFile): T = Line(i) ::: file(f)
48370
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    25
38722
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    26
  object Range
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    27
  {
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    28
    def apply(range: Text.Range): T = Offset(range.start) ++ Offset(range.stop)
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    29
    def unapply(pos: T): Option[Text.Range] =
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    30
      (Offset.unapply(pos), End_Offset.unapply(pos)) match {
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    31
        case (Some(start), Some(stop)) if start <= stop => Some(Text.Range(start, stop))
39041
6c8d0ea646a6 Position.Range: exclude singularity (again);
wenzelm
parents: 38887
diff changeset
    32
        case (Some(start), None) => Some(Text.Range(start, start + 1))
38722
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    33
        case _ => None
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    34
      }
ba31936497c2 organized markup properties via apply/unapply patterns;
wenzelm
parents: 38568
diff changeset
    35
  }
38872
26c505765024 Command.results: ordered by serial number;
wenzelm
parents: 38722
diff changeset
    36
38887
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    37
  object Id_Range
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    38
  {
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    39
    def unapply(pos: T): Option[(Long, Text.Range)] =
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    40
      (pos, pos) match {
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    41
        case (Id(id), Range(range)) => Some((id, range))
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    42
        case _ => None
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    43
      }
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    44
  }
1261481ef5e5 Command.State: add reported positions to markup tree, according main message position or Markup.binding/entity/report occurrences in body;
wenzelm
parents: 38872
diff changeset
    45
42327
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 41483
diff changeset
    46
  private val purge_pos = Map(
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    47
    Isabelle_Markup.DEF_LINE -> Isabelle_Markup.LINE,
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    48
    Isabelle_Markup.DEF_OFFSET -> Isabelle_Markup.OFFSET,
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    49
    Isabelle_Markup.DEF_END_OFFSET -> Isabelle_Markup.END_OFFSET,
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    50
    Isabelle_Markup.DEF_FILE -> Isabelle_Markup.FILE,
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    51
    Isabelle_Markup.DEF_ID -> Isabelle_Markup.ID)
42327
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 41483
diff changeset
    52
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 41483
diff changeset
    53
  def purge(props: T): T =
45666
d83797ef0d2d separate module for concrete Isabelle markup;
wenzelm
parents: 43780
diff changeset
    54
    for ((x, y) <- props if !Isabelle_Markup.POSITION_PROPERTIES(x))
42327
7c7cc7590eb3 Name_Space.entry_markup: keep def position as separate properties;
wenzelm
parents: 41483
diff changeset
    55
      yield (if (purge_pos.isDefinedAt(x)) (purge_pos(x), y) else (x, y))
48370
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    56
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    57
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    58
  def str_of(props: T): String =
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    59
    (Line.unapply(props), File.unapply(props)) match {
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    60
      case (Some(i), None) => " (line " + i.toString + ")"
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    61
      case (Some(i), Some(name)) => " (line " + i.toString + " of " + quote(name) + ")"
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    62
      case (None, Some(name)) => " (file " + quote(name) + ")"
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    63
      case _ => ""
d0fa3efec93b require explicit initialization of options;
wenzelm
parents: 45666
diff changeset
    64
    }
27968
85b5f024d94b Position properties.
wenzelm
parents:
diff changeset
    65
}