我正在尝试使用 FastParse 解析缩进语言,但我正在努力寻找有关它的任何资源或信息。
我只能在这里找到一个示例,它显示了如何解析和计算树结构中整数的总和。我尝试复制此代码,但在解析失败时遇到相同的错误\n
。
我想解析一下。
example
1
2
3
代码
import fastparse.all._
class ExampleParser(indent: Int) {
val word: P[String] = P("example".!)
val number: P[String] = P( CharIn('0'to'9').rep(1).! )
val blockBody: P[Seq[String]] = "\n" ~ deeper.flatMap(i => new ExampleParser(indent = i).number.rep(1, sep = ("\n" + " " * i).~/))
val deeper: P[Int] = P(" ".rep(indent + 1).!.map(_.length))
val section: P[(String, Seq[String])] = P(word ~ blockBody)
val expr: P[(String, Seq[String])] = P(section)
}
object Main
{
def main(args: Array[String]) =
{
check(
"""example
| 1
| 2
| 3
""".stripMargin.trim
)
println()
}
def check(str: String) = {
new ExampleParser(0).expr.parse(str) match {
case Parsed.Success(value, _) => println(value)
case Parsed.Failure(a, b, c) => println("Failure:" + a + ":" + b + ":" + c)
}
}
}
输出
Failure:"\n":7:Extra(...ample
1
2
3, [traced - not evaluated])
我怎样才能正确解析这个?