/*
* Document tokens as text ranges
*
* @author Johannes Hölzl, TU Munich
* @author Fabian Immler, TU Munich
*/
package isabelle.proofdocument
object Token {
object Kind {
val COMMAND_START = "COMMAND_START"
val COMMENT = "COMMENT"
}
def checkStart[C](t : Token[C], P : (Int) => Boolean)
= t != null && P(t.start)
def checkStop[C](t : Token[C], P : (Int) => Boolean)
= t != null && P(t.stop)
def scan[C](s : Token[C], f : (Token[C]) => Boolean) : Token[C] = {
var current = s
while (current != null) {
val next = current.next
if (next == null || f(next))
return current
current = next
}
return null
}
}
class Token[C](var start : Int, var stop : Int, var kind : String) {
var next : Token[C] = null
var previous : Token[C] = null
var command : C = null.asInstanceOf[C]
def length = stop - start
def shift(offset : Int, bottomClamp : Int) {
start = bottomClamp max (start + offset)
stop = bottomClamp max (stop + offset)
}
override def hashCode() : Int = (31 + start) * 31 + stop
override def equals(obj : Any) : Boolean = {
if (super.equals(obj))
return true;
if (null == obj)
return false;
obj match {
case other: Token[_] =>
(start == other.start) && (stop == other.stop)
case other: Any => false
}
}
}