我正在尝试为R6RS编写词法分析器/解析器,但我被跳过数据的注释卡住了
以下是我的词法分析器/解析器规则的一部分:
BOOLEAN: '#t' | '#f' | '#T' | '#F';
NUMBER: DIGIT+; // TODO: incomplete
CHAR: '#\\' CHARNAME | '#\\x' HEXDIGIT+ | '#\\' . ;
STRING: '"' STRELEMENT* '"';
IDENTIFIER: INITIAL SUBSEQUENT* | PERCULIAR_ID;
COMMENT: (';' .*? LINE_ENDING | '#!r6rs' ) -> skip;
NESTED_COMMENT: '#|' (NESTED_COMMENT | ~[#|] | ('|' ~'#') | ('#' ~'|') )* '|#' -> skip;
datum: lexemeDatum
| compoundDatum;
compoundDatum: list
| vector
| bytevector;
// (rest omitted...)现在,我想像skipDatum: '#;' datum -> skip一样编写代码。不幸的是,解析器规则不允许使用->skip。这两个SKIPDATUM: '#;' datum -> skip都不能工作,因为词法分析器规则不能引用解析器规则。
在我看来,虽然“注释掉”是词法分析器的责任,“构造数据”是解析器的责任,但是关于#;的规则需要两者。
这是我目前的解决方案:
skipDatum: '#;' datum;
list: '(' (datum|skipDatum)* ')' #ProperListDatum
| '[' (datum|skipDatum)* ']' #ProperListDatum
| '(' skipDatum* datum (datum|skipDatum)* '.' skipDatum* datum skipDatum* ')' #ImproperListDatum
| '[' skipDatum* datum (datum|skipDatum)* '.' skipDatum* datum skipDatum* ']' #ImproperListDatum当它工作时,它看起来非常丑陋;当我真的想要使用datum编写规则时,我总是必须像skipDatum* datum skipDatum*一样编写
有没有更好的解决方案?提前谢谢。
发布于 2013-04-23 21:16:01
你可以用到这样的东西。
datum
: SKIP_DATUM? ...
;
SKIP_DATUM : '#;';这将要求您在每次在生成的代码中使用DatumContext时执行以下检查,同时简化语法。
if (ctx.SKIP_DATUM() != null) {
// handle skipped datum here (return?)
}https://stackoverflow.com/questions/16169619
复制相似问题