Я попытался проанализировать ввод двух Ints и некоторых элементов и конец:
import scala.util.parsing.combinator.JavaTokenParsers
class X extends JavaTokenParsers {
lazy val elems = elem("wrong elem", "#WB-" contains _)
lazy val lists = repsep(rep(elems), ",")
lazy val p1 = int ~ int ~ lists
lazy val p2 = int ~ int ~ (whiteSpace ~> lists)
def go[A](p: Parser[A]) = parseAll(p, "1 2 WB#,---,BBB") match {
case NoSuccess(msg, _) => sys.error(msg)
case _ =>
}
lazy val int: Parser[Int] =
wholeNumber ^^ {
try _.toInt catch {
case e: NumberFormatException => sys.error("invalid number")
}
}
}
Пример ввода приведен в методе go
.Ints и элементы в конце должны быть разделены пробелами.Но это работает только для Ints, а не для элементов.Когда я набираю
val x = new X
x go x.p1
, я получаю следующую ошибку:
java.lang.RuntimeException: string matching regex `\z' expected but `W' found
Но когда я набираю
x go x.p1
, я получаю:
java.lang.RuntimeException: string matching regex `\s+' expected but `W' found
В конце я хочу получить Parser[Int ~ Int ~ List[List[Char]]]
.Почему вставка пробелов перед elem
не работает?И как мне заставить этот код работать?