0

我正在使用 flex 和 yacc 将一个小型线程解释器移动到 re2c 和柠檬。一切正常,但文字。

为什么与文字相关的操作无法像使用 yacc 一样运行?我期望“1.0 end”但得到“0.0 end”

dsp语法

%include {#include <assert.h>}
%name dsp
%token_type {float}
program   ::= expr.    {printf("end\n");}
expr(val) ::= LITERAL. {printf("%f ", val);}

主程序

#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
4

1 回答 1

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 */ }
于 2015-09-01T23:31:47.127 回答