如何使用scala组合解析器抛出有意义消息的异常?

时间:2010-10-21 00:01:18

标签: parsing scala grammar

当语言不符合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]因为人们会更直观地知道它是什么。

由于

1 个答案:

答案 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))
  }
}