summaryrefslogtreecommitdiff
path: root/src/library
diff options
context:
space:
mode:
authorPaul Phillips <paulp@improving.org>2012-08-17 09:29:22 -0700
committerPaul Phillips <paulp@improving.org>2012-08-17 09:31:24 -0700
commitb16ea5075c7ffb5fc57eb44f06dadbf5eacb64ec (patch)
tree19215d33fdee1b1b5bfa83184d0a63f667ae8cfa /src/library
parent7fc860963a4f76cb18e44c20f2bdfb49641033f3 (diff)
downloadscala-b16ea5075c7ffb5fc57eb44f06dadbf5eacb64ec.tar.gz
scala-b16ea5075c7ffb5fc57eb44f06dadbf5eacb64ec.tar.bz2
scala-b16ea5075c7ffb5fc57eb44f06dadbf5eacb64ec.zip
Restored lastNoSuccess to Parsers.
It was in 2.9.2 and can't be removed without deprecation.
Diffstat (limited to 'src/library')
-rw-r--r--src/library/scala/util/parsing/combinator/Parsers.scala18
1 files changed, 12 insertions, 6 deletions
diff --git a/src/library/scala/util/parsing/combinator/Parsers.scala b/src/library/scala/util/parsing/combinator/Parsers.scala
index 66e0a496d8..eaaea583ce 100644
--- a/src/library/scala/util/parsing/combinator/Parsers.scala
+++ b/src/library/scala/util/parsing/combinator/Parsers.scala
@@ -155,14 +155,20 @@ trait Parsers {
val successful = true
}
- private lazy val lastNoSuccess = new DynamicVariable[Option[NoSuccess]](None)
+ private lazy val lastNoSuccessVar = new DynamicVariable[Option[NoSuccess]](None)
+
+ @deprecated("lastNoSuccess was not thread-safe and will be removed in 2.11.0", "2.10.0")
+ def lastNoSuccess: NoSuccess = lastNoSuccessVar.value.orNull
+
+ @deprecated("lastNoSuccess was not thread-safe and will be removed in 2.11.0", "2.10.0")
+ def lastNoSuccess_=(x: NoSuccess): Unit = lastNoSuccessVar.value = Option(x)
/** A common super-class for unsuccessful parse results. */
sealed abstract class NoSuccess(val msg: String, override val next: Input) extends ParseResult[Nothing] { // when we don't care about the difference between Failure and Error
val successful = false
- if (lastNoSuccess.value map { v => !(next.pos < v.next.pos) } getOrElse true)
- lastNoSuccess.value = Some(this)
+ if (lastNoSuccessVar.value forall (v => !(next.pos < v.next.pos)))
+ lastNoSuccessVar.value = Some(this)
def map[U](f: Nothing => U) = this
def mapPartial[U](f: PartialFunction[Nothing, U], error: Nothing => String): ParseResult[U] = this
@@ -881,14 +887,14 @@ trait Parsers {
* if `p` consumed all the input.
*/
def phrase[T](p: Parser[T]) = new Parser[T] {
- def apply(in: Input) = lastNoSuccess.withValue(None) {
+ def apply(in: Input) = lastNoSuccessVar.withValue(None) {
p(in) match {
case s @ Success(out, in1) =>
if (in1.atEnd)
s
else
- lastNoSuccess.value filterNot { _.next.pos < in1.pos } getOrElse Failure("end of input expected", in1)
- case ns => lastNoSuccess.value.getOrElse(ns)
+ lastNoSuccessVar.value filterNot { _.next.pos < in1.pos } getOrElse Failure("end of input expected", in1)
+ case ns => lastNoSuccessVar.value.getOrElse(ns)
}
}
}