- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试实现 BNF for EPD在 Pharo/PetitParser 中。
digit18 := $1 asParser / $2 asParser / $3 asParser / $4 asParser / $5 asParser / $6 asParser / $7 asParser / $8 asParser.
piecePromotion := $N asParser / $B asParser / $R asParser / $Q asParser.
promotion := ($= asParser) , piecePromotion.
fileLetter := ($a asParser / $b asParser / $c asParser / $d asParser / $e asParser / $f asParser / $g asParser / $h asParser).
targetSquare := fileLetter , digit18.
disambiguation := fileLetter / digit18.
pieceCode := ($N asParser / $B asParser / $R asParser / $Q asParser / $K asParser) optional.
castles := $O asParser, $- asParser, $O asParser, (($- asParser, $O asParser) optional) .
sanMove := (pieceCode, disambiguation optional, targetSquare, promotion optional, ($+ asParser / $# asParser) optional) "/ castles". "commented out because I'd be getting another error with this enabled"
然后我尝试像这样解析:
element := PPUnresolvedParser new.
element def: ( sanMove ).
mse := element end.
mse parse: 'Re4'.
但我收到此错误:
$h expected at 2 // btw these indexes seem to start at 0
如果我尝试使用 Ree4
作为输入,它会成功解析为 #($R $e #($e $4) nil nil)
。这让我认为消歧的可选标志无法正常工作,并且解析器不会尝试查看它是否在不将“e”解析为消歧的情况下进行解析,即使它可以是。但它导致无法解析强制 targetSquare
,所以我不明白为什么 PetitParser 放弃。
最佳答案
Parsing Expression Grammars (PetitParser 使用的解析器技术)是贪婪的。这意味着一旦成功消耗了某些东西,他们就不会再回头。在您的情况下,规则“消歧”已成功使用,因此即使解析器稍后卡住,解析器也不会重试跳过它。
BNF 和 PEG 语法看起来很相似,但它们的语义却截然不同。因此,您不能将 BNF 语法规则逐条翻译为 PetitParser。您必须仔细安排选择(PEG 中的顺序很重要)。在您的特定示例中,您可以将 sanMove 更改为:
sanMove := pieceCode, ((targetSquare, promotion optional, ($+ asParser / $# asParser) optional) / (disambiguation optional, targetSquare, promotion optional, ($+ asParser / $# asParser) optional)).
根据该规则,您的两个测试都会解析:
sanMove end parse: 'Ree4'.
sanMove end parse: 'Re4'.
关于parsing - 如何使用 PetitParser 防止贪婪?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9439817/
PetitParser 中的规则是分布式的吗? 有以下规则: integerLiteral --> hexIntegerLiteral / octalIntegerLiteral / decimalI
我想要一个只识别 0 到 32767 之间的数字的解析规则。我尝试了类似的方法: integerConstant ^ (#digit asParser min: 1 max: 5) flatten
我定义了一个规则: def("invokation", char('@').word().plus().flatten()); 对于“@who”,它将匹配并得到 @who结果。 怎么问才回who没有
据我所知,PetitParser 使用同名的生产方法初始化每个实例变量。应该怎么做,例如添加自定义实例变量并在 initialize 方法中对其进行初始化? 最佳答案 您可以覆盖子类中的类端方法#ig
我想使用 PetitParser 解析编程语言中的标识符。 要求之一是标识符的名称不是关键字(例如 null ),因此 null将不是有效的标识符。 对于这种情况,我能想到的最小解析器是: ident
有一个内置whitespace()解析器在 PetitParserDart ,它检查字符: (9 <= value && value <= 13) || (value == 32) || (value
在 http://pharobooks.gforge.inria.fr/PharoByExampleTwo-Eng/latest/ ,定义了一个ExpressionGrammar。然而,它是右关联的
我正在尝试实现 BNF for EPD在 Pharo/PetitParser 中。 digit18 := $1 asParser / $2 asParser / $3 asParser / $4 as
我正在尝试用 PetitParser 制作一个基本的数学解析器,并且我无法使用非对称二元运算符(如减法或除法)获得正确的顺序。 我有这个小例子,它只能解析(非负)整数和 - 二元运算符,并发出一个带有
petitparser是用 dart 编写的解析器生成器用于例如在 Flutter . 根据 this page , petitparser允许使用 ref0 来引用当前的解析类。 在使用语法定义部分
是否有像 plus() 这样具有上限的解析器,可以对 Item <- [a-zA-Z0-9]{1,5} 这样的表达式进行建模? 对于像Item <- [a-zA-Z0-9]{3,5}这样的东西也类似。
在 PetitParser2 中,如何匹配一组封闭的标记,例如月份名称?例如。 (伪代码)[:单词 | MonthNames anySatisfy: [ :mn | mn beginsWith: wo
我有一个编程语言语法,我想在 PPCompositeParser 的几个子类中展开(例如,一个类将处理指令,另一个类将处理表达式,另一个类将处理程序结构)。我想这样做是为了避免获得一个包含数十个实例变
我正在考虑在我的项目中使用 petitparser for Dart ( https://pub.dartlang.org/packages/petitparser )。我想用它来处理存储为字符串的
这是我试图在 PetitParser 中实现的(简化的)EBNF 部分: variable :: component / identifier component :: indexed / field
我想解析 'This,is,an,example,text' 就像在 findTokens 中一样 'This,is,an,example,text' findTokens: $, an Ordere
据我所知,PetitParser是一个解析器,我们可以定义语法和 Action 来解析一些文本。 我已经成功地使用它内置的 JSON 解析器来解析一些 JSON 字符串,但我想做更多。我想编写一个 J
我是一名优秀的程序员,十分优秀!