我一直在做学校作业,在弄清楚哪个问题导致“默认操作类型冲突”下的多个警告时遇到困难。任何帮助将不胜感激。
收到的警告:
parser.y:62.9-23: warning: type clash on default action: <value> != <> parser.y:71.9-16: warning: type clash on default action: <value> != <> parser.y:82.5-23: warning: type clash on default action: <value> != <iden> parser.y:83.5-27: warning: type clash on default action: <value> != <iden> parser.y:104.5-55: warning: type clash on default action: <value> != <> parser.y:105.5-60: warning: type clash on default action: <value> != <> parser.y:108.5-37: warning: type clash on default action: <value> != <> parser.y:122.49-53: warning: type clash on default action: <oper> != <> parser.y:122.57-60: warning: type clash on default action: <oper> != <> parser.y:127.5-14: warning: type clash on default action: <value> != <iden> parser.y:157.9-35: warning: type clash on default action: <value> != <iden> parser.y:160.9-20: warning: type clash on default action: <value> != <> parser.y:161.9-21: warning: type clash on default action: <value> != <oper>
parser.y
%{
#include <iostream>
#include <string>
#include <vector>
#include <map>
using namespace std;
#include "values.h"
#include "listing.h"
#include "symbols.h"
int yylex();
void yyerror(const char* message);
Symbols<int> symbols;
int result;
%}
%error-verbose
%union
{
CharPtr iden;
Operators oper;
int value;
}
%token <value> INT_LITERAL REAL_LITERAL INTEGER REAL
%token <iden> IDENTIFIER
%token ARROW
%token ANDOP OROP
%token <oper> NOTOP EXPOP MULOP REMOP ADDOP RELOP
%token BOOL_LITERAL BOOLEAN
%token IF THEN ELSE ENDIF CASE OTHERS ENDCASE WHEN
%token BEGIN_ END ENDREDUCE FUNCTION IS REDUCE RETURNS
%type <value> function_header_ body variable_ parameter cases case statements statement_ statement reductions exponent expression logical relation term
factor power primary
%type <oper> operator
%%
function:
function_header_ variables body {result = $3;} ;
function_header:
FUNCTION IDENTIFIER parameters RETURNS type ';' ;
function_header_:
function_header |
error ';' {$$ = 0;} ;
statement_:
statement ';' |
error ';' {$$ = 0;} ;
variable_:
variable |
error ';' {$$ = 0;} ;
variable:
IDENTIFIER ':' type IS statement_ {symbols.insert($1, $5);} ;
variables:
variables variable_ |
;
parameter:
IDENTIFIER ':' type |
IDENTIFIER ':' type ',' ;
parameters:
parameters parameter |
;
type:
INTEGER | REAL |
BOOLEAN ;
body:
BEGIN_ statement_ END ';' {$$ = $2;} ;
statements:
statements statement_ |
statement_ ;
statement:
expression |
REDUCE operator reductions ENDREDUCE {$$ = $3;} |
IF expression THEN statements ELSE statements ENDIF |
CASE expression IS cases OTHERS ARROW statement_ ENDCASE ;
case:
WHEN INT_LITERAL ARROW statement_;
cases:
cases case |
case
;
reductions:
reductions statement_ {$$ = evaluateReduction($<oper>0, $1, $2);} |
{$$ = $<oper>0 == ADD ? 0 : 1;} ;
operator:
NOTOP | MULOP | REMOP | ADDOP | RELOP | ANDOP | OROP ;
exponent:
INT_LITERAL |
REAL_LITERAL |
IDENTIFIER ;
expression:
expression OROP logical {$$ = $1 || $3;} |
logical ;
logical:
logical ANDOP relation {$$ = $1 && $3;} |
relation ;
relation:
relation RELOP term {$$ = evaluateRelational($1, $2, $3);} |
term ;
term:
term ADDOP factor {$$ = evaluateArithmetic($1, $2, $3);} |
factor ;
factor:
factor MULOP power {$$ = evaluateArithmetic($1, $2, $3);} |
factor REMOP power {$$ = evaluateArithmetic($1, $2, $3);} |
power ;
/* right-associative */
power:
primary EXPOP exponent {$$ = evaluateArithmetic($1, $2, $3);}
;
primary:
IDENTIFIER {if (!symbols.find($1, $$)) appendError(UNDECLARED, $1);} |
IDENTIFIER '('expression')' |
INT_LITERAL |
REAL_LITERAL |
BOOL_LITERAL |
NOTOP primary |
'(' expression ')' {$$ = $2;}
;
%%
void yyerror(const char* message)
{
appendError(SYNTAX, message);
}
int main(int argc, char *argv[])
{
firstLine();
yyparse();
if (lastLine() == 0)
cout << "Result = " << result << endl;
return 0;
}
scanner.l
%{
#include <cstdio>
#include <string>
using namespace std;
#include "values.h"
#include "listing.h"
#include "tokens.h"
int l=0,r=0,cbl=0,cbr=0;
%}
%option noyywrap
ws [ \t\r]+
comment \-\-.*\n|\/\/.*\n
line [\n]
arrow =>
if if|IF
endcase endcase|ENDCASE
case case|CASE
endif endif|ENDIF
else else|ELSE
others others|OTHERS
real real|REAL
then then|THEN
when when|WHEN
begin begin|BEGIN
boolean boolean|BOOLEAN
endreduce endreduce|ENDREDUCE
end end|END
function function|FUNCTION
integer integer|INTEGER
is is|IS
reduce reduce|REDUCE
returns returns|RETURNS
and and|AND
or or|OR
not not|NOT
bool_lit true|false|TRUE|FALSE
bad_underscore [A-Za-z0-9_]*[_]{2}[A-Za-z0-9_]*|^[_][A-Za-z0-9_]*|[A-Za-z0-9_]*[_]+$
digit [0-9]
int [\-|\+]{0,1}{digit}+
punc [\(\),:;]
real_lit [\-|\+]{0,1}[0-9]+[\.][0-9]+[e|E][\-|\+][0-9]+|[\-|\+]{0,1}[0-9]*[\.][0-9]+|[\-|\+]{0,1}[0-9]+[\.][0-9]*
id [A-Za-z][A-Za-z0-9_]*
%%
{ws} { ECHO; }
{comment} { ECHO; nextLine();}
{line} { ECHO; nextLine();}
{arrow} { ECHO; return(ARROW); }
"<" { ECHO; yylval.oper = LESS; return(RELOP); }
">" { ECHO; yylval.oper = GREATER; return(RELOP); }
">=" { ECHO; yylval.oper = GREATER_OR_EQUALS; return(RELOP); }
"<=" { ECHO; yylval.oper = LESS_OR_EQUALS; return(RELOP); }
"=" { ECHO; yylval.oper = EQUALS; return(RELOP); }
"+" { ECHO; yylval.oper = ADD; return(ADDOP); }
"-" { ECHO; yylval.oper = SUBTRACT; return(ADDOP); }
"**" { ECHO; yylval.oper = EXPONENT; return(EXPOP); }
"*" { ECHO; yylval.oper = MULTIPLY; return(MULOP); }
"/" { ECHO; yylval.oper = DIVIDE; return(MULOP); }
"REM" { ECHO; yylval.oper = REMAINDER; return(REMOP); }
"rem" { ECHO; yylval.oper = REMAINDER; return(REMOP); }
{if} { ECHO; return(IF); }
{endcase} { ECHO; return(ENDCASE); }
{case} { ECHO; return(CASE); }
{endif} { ECHO; return(ENDIF); }
{else} { ECHO; return(ELSE); }
{others} { ECHO; return(OTHERS); }
{real} { ECHO; return(REAL); }
{then} { ECHO; return(THEN); }
{when} { ECHO; return(WHEN); }
{begin} { ECHO; return(BEGIN_); }
{boolean} { ECHO; return(BOOLEAN); }
{endreduce} { ECHO; return(ENDREDUCE); }
{end} { ECHO; return(END); }
{function} { ECHO; return(FUNCTION); }
{integer} { ECHO; return(INTEGER); }
{is} { ECHO; return(IS); }
{reduce} { ECHO; return(REDUCE); }
{returns} { ECHO; return(RETURNS); }
{and} { ECHO; return(ANDOP); }
{or} { ECHO; return(OROP); }
{not} { ECHO; return(NOTOP); }
{real_lit} { ECHO; return(REAL_LITERAL); }
{bool_lit} { ECHO; return(BOOL_LITERAL); }
{id} { ECHO; yylval.iden = (CharPtr)malloc(yyleng + 1);
strcpy(yylval.iden, yytext); return(IDENTIFIER);}
{int} { ECHO; yylval.value = atoi(yytext); return(INT_LITERAL); }
{punc} { ECHO; return(yytext[0]); }
. { ECHO; appendError(LEXICAL, yytext); }
%%
答案 0 :(得分:0)
这些是没有明确操作的规则中默认操作的类型不匹配。第一个来自规则
function_header_: function_header
在第62行。由于此处没有操作,因此它获得操作{ $$ = $1; }
,但是$$
的类型为<value>
(来自%type <value> function_header_
声明),而{{ 1}}没有类型(所以$1
,因为<>
没有%type
声明)