X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/b9cecb91a08fa4baa73a5e12a83611b41507a022..0993971437a9c6d5328f172ed4c44969d4f09ab7:/tests/headers.at diff --git a/tests/headers.at b/tests/headers.at index 5e2facb4..7865341c 100644 --- a/tests/headers.at +++ b/tests/headers.at @@ -55,15 +55,20 @@ m4_define([AT_TEST_CPP_GUARD_H], dirname=`AS_DIRNAME([$1])` AS_MKDIR_P([$dirname]) -AT_DATA([$1.y], -[%% -dummy: +AT_DATA_GRAMMAR([$1.y], +[%{ +#include "$1.h" +%} +%% +dummy:; +%% +#include "$1.h" ]) -AT_CHECK([bison --defines=$1.h $1.y]) +AT_CHECK([bison --defines=$1.h --output=y.tab.c $1.y]) # CPP should be happy with it. -AT_CHECK([$CC -E $1.h], 0, [ignore]) +AT_CHECK([$CC -E -I. y.tab.c], 0, [ignore]) AT_CLEANUP ]) @@ -80,20 +85,22 @@ AT_TEST_CPP_GUARD_H([9foo]) AT_SETUP([export YYLTYPE]) -AT_DATA([input.y], +AT_DATA_GRAMMAR([input.y], [%locations + +%name-prefix="my_" %{ #include #include static int -yylex (void) +my_lex (void) { return EOF; } static void -yyerror (const char *msg) +my_error (const char *msg) { fprintf (stderr, "%s\n", msg); } @@ -103,25 +110,27 @@ yyerror (const char *msg) exp:; ]) -AT_CHECK([bison --defines input.y -o input.c]) +AT_CHECK([bison --defines -o input.c input.y]) -# YYLTYPE should be defined, and YYLLOC declared. +# YYLTYPE should be defined, and MY_LLOC declared. AT_DATA([caller.c], [[#include "input.h" -YYLTYPE *yyllocp = &yylloc; +YYLTYPE *my_llocp = &my_lloc; -int yyparse (void); +int my_parse (void); int main (void) { - return yyparse (); + return my_parse (); } ]]) # Link and execute, just to make sure everything is fine (and in -# particular, that YYLLOC is indeed defined somewhere). -AT_CHECK([$CC $CFLAGS $CPPFLAGS caller.c input.c -o caller], 0, [], [ignore]) -AT_CHECK([caller]) +# particular, that MY_LLOC is indeed defined somewhere). +AT_COMPILE([caller.o], [-c caller.c]) +AT_COMPILE([input.o], [-c input.c]) +AT_COMPILE([caller], [caller.o input.o]) +AT_PARSER_CHECK([./caller]) AT_CLEANUP