在bisonc ++中正确接受括号

时间:2016-02-28 20:31:02

标签: c++ flex-lexer bisonc++

我尝试使用bisonc++

编写基本语法检查程序

规则是:

expression -> OPEN_BRACKET expression CLOSE_BRACKET
expression -> expression operator expression

operator -> PLUS
operator -> MINUS

如果我尝试运行已编译的代码,我会在此行收到错误:

(a+b)-(c+d)

应用第一个规则,最左边和最右边的括号是OPEN_BRACKETCLOSE_BRACKET。剩下的expression是:a+b)-(c+d

如何防止此行为?是否可以计算开括号和闭括号?

修改

表达式语法:

expression:
    OPEN_BRACKET expression CLOSE_BRACKET
    {
        //
    }        
| operator
    {
        //
    }        
| VARIABLE
    {
        //
    }

;


operator:
    expression PLUS expression
    {
        //
    }

| expression MINUS expression
    {
        //
    }

;

EDIT2

词法分析器

CHAR  [a-z]
WS    [ \t\n]

%%

{CHAR}+     return Parser::VARIABLE;

"+"         return Parser::PLUS;
"-"         return Parser::MINUS;

"("         return Parser::OPEN_BRACKET;
")"         return Parser::CLOSE_BRACKET;

2 个答案:

答案 0 :(得分:4)

这不是正常的表达式语法。试试正常的。

expression
    : term
    | expression '+' term
    | expression '-' term
    ;
term
    : factor
    | term '*' factor
    | term '/' factor
    | term '%' factor
    ;
factor
    : primary
    | '-' factor // unary minus
    | primary '^' factor // exponentiation, right-associative
    ;
primary
    : identifier
    | literal
    | '(' expression ')'
    ;

还要注意上面的缩进和对齐方法,并且您只需要从词法分析器返回yytext[0]单个特殊字符:您不需要特殊的令牌名称,而且它不需要没有它们更具可读性:

CHAR [a-zA-Z]
DIGIT [0-9]
WHITESPACE [ \t\r\n]
%%
{CHAR}+       { return Parser::VARIABLE; }
{DIGIT}+      { return Parser::LITERAL; }
{WHITESPACE}+ ;
.             { return yytext[0]; }

答案 1 :(得分:1)

您的运营商规则看起来不太好。

尝试使用:

expression:
    OPEN_BRACKET expression CLOSE_BRACKET
    {
        //
    }

|

    expression operator expression
    {
        //
    }

|

    VARIABLE
    {
        //
    }

;


operator:
    PLUS
    {
        //
    }

|

    MINUS
    {
        //
    }
;

正如您的伪代码实际建议......