こんにちは私はそれがどのように機能するかを学ぶために小さなバイソンに取り組んでいます。バイソンは文を解析することになっています。文は表現で構成され、表現は単語で構成されています。
以下は私のコードです:
%{
#include <stdio.h>
#include <string.h>
void yyerror(const char *str)
{
fprintf(stderr,"error: %s\n",str);
}
int yywrap()
{
return 1;
}
main()
{
yyparse();
}
%}
%token ASSIGN RANGE OR AND WHITESPACE QUOTE LPAREN RPAREN NOT GREATER LESS
%union
{
int number;
char *string;
}
%token <number> VALUE
%token <string> WORD
%type <string> term
%type <string> expression
%%
query: /* empty */
| query expression
{
printf("WOrd:%s",$2);
}
;
expression:
term
|expression term
|expression AND term
{
printf("AND");
}
;
term:
WORD
{
$$=$1;
}
;
したがって、ユーザーが単語を入力すると、その単語が印刷されることになっています。ユーザーは次のように入力できる必要があります:単語、単語単語、単語、単語
$$を使用して単語を渡し、「クエリ式」ルールから出力する方法がわかりません。どうすればよいですか?
これは私のフレックスです:
%{
#include <stdio.h>
#include <string.h>
#include "y.tab.h"
%}
%%
[0-9]+ yylval.number=atoi(yytext);return VALUE;
[a-zA-Z][a-zA-Z]* yylval.string=strdup(yytext);return WORD;
":" return ASSIGN;
"and"|"&"|"&&" return AND;
".." return RANGE;
"-" return NOT;
"|" return OR;
"\"" return QUOTE;
">" return GREATER;
"<" return LESS;
\n /* ignore end of line */;
\t /* ignore end of line */;
%%
事前に感謝します。サラ