当语言不符合scala组合解析器的语法时,我想抛出一个异常。以下是规则的示例:
def record: Parser[Record] = "-" ~ opt(recordLabel) ~ repsep(column, ",") ^^ {
case "-" ~ label ~ columns => new Record(label, columns)
}
让我们说在repsep(列,“,”)部分,他们意外地创建一个像这样的字符串
a, b, c, d,
这是无效的,因为它以“,”结束,而不是假设存在。当你调用parseAll()时,而不是解析器只是停止,你如何使这个抛出一个人类可读的有意义的异常? (自定义文本,行号等)
编辑:好的,我找到了可行的方法,但我对它的可定制性不满意:def loadFrom(filename: String) {
val source =
Source.fromFile(filename).getLines.mkString("\n")
val parseResult = parseAll(tables, source)
if(!parseResult.successful) {
throw new TestDataParseException(parseResult.toString)
}
}
toString打印出一条好的消息,但是当它找到一个空格时(它有时看起来像我的IDE中的块/方块),它打印出奇怪的东西,比如想要“\ z”。我宁愿说,“嘿,你忘记了一个逗号!”
行号/列以[x.y]的形式打印出来。我实际上想要显示[Line:x,Column:y]因为人们会更直观地知道它是什么。
由于
答案 0 :(得分:7)
parseAll(tables, source) match {
case Success(ast, _) => //do something
case NoSuccess(msg, next) => {
println("Failed at line %s, column %s: %s".format(
next.pos.line, next.pos.column, msg))
}
}