我正在使用flex和yacc将一个小型线程解释器移动到re2c和lemon。一切都在运作,但文字。
为什么与文字相关联的操作无法像yacc那样运行?我希望" 1.0结束"但得到" 0.0结束"
dspgrammar.y
%include {#include <assert.h>}
%name dsp
%token_type {float}
program ::= expr. {printf("end\n");}
expr(val) ::= LITERAL. {printf("%f ", val);}
的main.c
#include <stdio.h>
#include <stdlib.h>
#include "dspgrammar.h"
void *dspAlloc(void *(*)(size_t));
void dsp(void *, int, float);
void dspFree(void *, void (*)(void *));
void dspTrace(FILE *, char *);
int main(int argc, char *argv[])
{
void *parser = dspAlloc(malloc);
dspTrace(stderr, "TRACE: ");
dsp(parser, LITERAL, 1.0f);
dsp(parser, 0, 0.0f);
dspFree(parser, free);
return EXIT_SUCCESS;
}
生成文件
CC = gcc
CFLAGS = -O0 -g -Wall -Wextra -pedantic -std=gnu99
LD = gcc
LDFLAGS = -lm
dsp: main.o dspgrammar.o
$(LD) $(CFLAGS) -o $@ $^ $(LDFLAGS)
main.o: main.c
$(CC) $(CFLAGS) -c main.c
dspgrammar.o: dspgrammar.c
$(CC) -c $(CFLAGS) -c dspgrammar.c
dspgrammar.c: dspgrammar.y
lemon dspgrammar.y
答案 0 :(得分:1)
在
expr(val) ::= LITERAL. { /* something with val */ }
val
是减少值的名称。换句话说,它对应于yacc中的$$
。终端LITERAL
的语义值为$1
,因为您没有为该值提供符号名称。
也许你的意思是:
expr ::= LITERAL(val). { /* something with val */ }
或者
expr(e) ::= LITERAL(v). { e = v; /* some other action */ }