在Scala解析器组合器中使用Positional和positioned() [英] Using Positional and positioned() in scala parser combinators

查看:121
本文介绍了在Scala解析器组合器中使用Positional和positioned()的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

具有单独的Lexer和Parser ...

With separate Lexer and Parser ...

class YamlLexical extends StdLexical with YamlTokens with RegexParsers {...
object YamlParser extends StdTokenParsers with YamlTokens with PackratParsers {...

...如何将已解析的字符串的位置放入AST类中?

... how to get the position of the parsed string into AST classes?

(... positioned(elem(...)) * ... )^^ { ... => List( Ast(startpos, parsedtext, ... subnodes ... ), ... )}

推荐答案

positioned的类型为

def positioned[T <: Positional](p: ⇒ Parser[T]): Parser[T]

表示已解析的元素必须扩展Positional.因此,例如,YamlLexical应该是:

which means that the parsed elements must extend Positional. So, for example, YamlLexical should be:

class YamlLexical extends Positional 

以这种方式,任何已解析的元素将自动具有pos,该pos记录了其被解析的位置.

in that way, any parsed element will automatically have a pos which records the position in which it was parsed.

这篇关于在Scala解析器组合器中使用Positional和positioned()的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆