我一直在处理Marpa解析器,当第一个符号是可选的时,我遇到了一个问题。下面是一个例子:
use strict;
use warnings;
use 5.10.0;
use Marpa::R2;
use Data::Dump;
my $grammar = Marpa::R2::Scanless::G->new({source => \<<'END_OF_GRAMMAR'});
:start ::= Rule
Rule ::= <optional a> 'X'
<optional a> ~ a *
a ~ 'a'
END_OF_GRAMMAR
my $recce = Marpa::R2::Scanless::R->new({grammar => $grammar});
dd $recce->read(\"X");当我运行这个程序时,我会得到以下错误:
Error in SLIF parse: No lexemes accepted at line 1, column 1
* String before error:
* The error was at line 1, column 1, and at character 0x0058 'X', ...
* here: X
Marpa::R2 exception at small.pl line 20
at /usr/local/lib/perl/5.14.2/Marpa/R2.pm line 126
Marpa::R2::exception('Error in SLIF parse: No lexemes accepted at line 1, column 1\x{a}...') called at /usr/local/lib/perl/5.14.2/Marpa/R2/Scanless.pm line 1545
Marpa::R2::Scanless::R::read_problem('Marpa::R2::Scanless::R=ARRAY(0x95cbfd0)', 'no lexemes accepted') called at /usr/local/lib/perl/5.14.2/Marpa/R2/Scanless.pm line 1345
Marpa::R2::Scanless::R::resume('Marpa::R2::Scanless::R=ARRAY(0x95cbfd0)', 0, -1) called at /usr/local/lib/perl/5.14.2/Marpa/R2/Scanless.pm line 926
Marpa::R2::Scanless::R::read('Marpa::R2::Scanless::R=ARRAY(0x95cbfd0)', 'SCALAR(0x95aeb1c)') called at small.pl line 20Perl版本5.14.2 (debian喘息)
Marpa版本2.068000
(我看到有一个全新的Marpa 2.069,我还没有试过)
这是我语法上做错了什么吗?
发布于 2013-09-05 11:19:51
在Marpa Scanless中,您的语法有两个级别:主要的、高级别的语法,您可以在其中属性动作之类的,以及低级的词法语法。它们是独立执行的(如果您使用了传统的解析器/词汇器,这是预料中的,但是当您从regexes到Marpa时非常混乱)。
现在,在低级语法中,Marpa将输入识别为单个X,而不是“零a,然后是X”。然而,高级语法要求存在optional a符号.
最好的方法是让a在高级语法中是可选的:
<optional a> ::= <many a>
<optional a> ::= # empty
<many a> ~ a* # would work the same here with "a+"
a ~ 'a'https://stackoverflow.com/questions/18634749
复制相似问题