0

flex と yacc を使用して小さなスレッド インタープリターを re2c と lemon に移動しています。すべてが機能していますが、リテラルです。

リテラルに関連付けられたアクションが yacc の場合のように実行できないのはなぜですか? 「1.0 end」を期待していますが、「0.0 end」を取得します

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
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 に答える