在Scala解析器组合器中使用Positional和positioned() [英] Using Positional and positioned() in scala parser combinators
本文介绍了在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屋!
查看全文