RE2C如何丢弃当前匹配的规则并继续尝试?

时间:2015-02-20 01:53:01

标签: c++ c re2c

匹配后是否可以有条件地丢弃规则并继续尝试优先级较低的其他规则?

<SOME_STATE>{rule} {
    if(condition) {
        return TOKEN;
    }
    // discard
    // continue and try the other rules below...
}

<SOME_STATE>{other_rule} {
    return OTHER_TOKEN;
}

...

PS:condition取决于其他无法与正则表达式匹配的分辨率

PS2:我已经搜索了手册:)

PS3:我无法通过推动新状态来解决这个问题

1 个答案:

答案 0 :(得分:1)

我假设您使用的是默认命令行选项,如果不是,请告诉我(示例-f可能会更改内容,但最终我要检查)。

作为简短的回答,我会说不,这是不可能的。

答案很长:

我个人觉得这个问题有点奇怪,也许你需要重新考虑扫描仪逻辑(忽略上层的令牌或者在 re2c块之前检查条件然后使用不同的< em> re2c block ?)。

即使可能保存光标并使用某些 goto 仍然效率低下,因为第一条规则将始终匹配。

#include <stdio.h>
#include <string.h>
#define RET(n) printf("%d\n", n); return n
int scan(int i, char *s, int l){
char *p = s;
char *q;
#define YYCTYPE         char
#define YYCURSOR        p
#define YYLIMIT         (s+l)
#define YYMARKER        q
/*!re2c
    re2c:yyfill:enable = 0;
    any = [\000-\377];
*/
YYCTYPE *sc = YYCURSOR; /* save cursor */
/*!re2c
    "rule"  {printf("rule match\n");if(i==1) {RET(1);}}
    any     {goto other;}
*/
other:
YYCURSOR = sc;
/*!re2c
    "rule2" {printf("rule2 match\n"); RET(2);}
    any     {if(YYCURSOR==YYLIMIT) RET(0);}
*/
}
int main(int argc, char **argv) {
    int i;
    for (i=1; i < argc; i++) {
        fprintf(stderr, "[%d]:%s\n", i, argv[i]);
        scan(i, argv[i], strlen(argv[i]));
    }
    return 0;
}

如果您可以提供函数实现的最小示例,那么规则和命令行选项会很有用。