X-Git-Url: https://git.saurik.com/bison.git/blobdiff_plain/eb1b07409f0ccad9970c8a60ded9f2a56d205b9c..62a87154b3bb1af77ee153603972090a600bafce:/tests/push.at diff --git a/tests/push.at b/tests/push.at index 62593d3e..adb51358 100644 --- a/tests/push.at +++ b/tests/push.at @@ -1,28 +1,27 @@ # Checking Push Parsing. -*- Autotest -*- -# Copyright (C) 2007 Free Software Foundation, Inc. -# This program is free software; you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation; either version 2, or (at your option) -# any later version. +# Copyright (C) 2007, 2009-2012 Free Software Foundation, Inc. +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. - +# # You should have received a copy of the GNU General Public License -# along with this program; if not, write to the Free Software -# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA -# 02110-1301, USA. +# along with this program. If not, see . AT_BANNER([[Push Parsing Tests]]) -## ---------------------------------------------- ## -## Push Parsing: Memory Leak for Early Deletion. ## -## ---------------------------------------------- ## +## -------------------------------- ## +## Memory Leak for Early Deletion. ## +## -------------------------------- ## -AT_SETUP([[Push Parsing: Memory Leak for Early Deletion]]) +AT_SETUP([[Memory Leak for Early Deletion]]) # Requires Valgrind. @@ -35,7 +34,7 @@ AT_DATA_GRAMMAR([[input.y]], void yyerror (char const *msg); %} -%pure-parser %push-parser +%define api.pure %define api.push-pull push %% @@ -52,31 +51,119 @@ yyerror (char const *msg) int main (void) { - yypstate *yyps; - YYSTYPE yylval; + yypstate *ps; + + /* Make sure we don't try to free ps->yyss in this case. */ + ps = yypstate_new (); + yypstate_delete (ps); + + /* yypstate_delete used to leak ps->yyss if the stack was reallocated but the + parse did not return on success, syntax error, or memory exhaustion. */ + ps = yypstate_new (); + assert (yypush_parse (ps, 'a', NULL) == YYPUSH_MORE); + yypstate_delete (ps); + + ps = yypstate_new (); + assert (yypush_parse (ps, 'a', NULL) == YYPUSH_MORE); + assert (yypush_parse (ps, 'b', NULL) == YYPUSH_MORE); + yypstate_delete (ps); + + return 0; +} +]]) + +AT_BISON_CHECK([[-o input.c input.y]]) +AT_COMPILE([[input]]) +AT_PARSER_CHECK([[./input]]) + +AT_CLEANUP + +## --------------------------- ## +## Multiple impure instances. ## +## --------------------------- ## + +AT_SETUP([[Multiple impure instances]]) + +m4_pushdef([AT_MULTIPLE_IMPURE_INSTANCES_CHECK], [ +AT_DATA_GRAMMAR([[input.y]], +[[ +%{ + #include + #include + void yyerror (char const *msg); + int yylex (void); +%} + +%define api.push-pull ]$1[ + +%% - /* Make sure we don't try to free yyps->yyss in this case. */ - yyps = yypstate_new (); - yypstate_delete (yyps); +start: ; - /* yypstate_delete used to leak yyps->yyss if the stack was reallocated but - the parse did not return on success, syntax error, or memory - exhaustion. */ - yyps = yypstate_new (); - assert (yypush_parse (yyps, 'a', &yylval) == YYPUSH_MORE); - yypstate_delete (yyps); +%% - yyps = yypstate_new (); - assert (yypush_parse (yyps, 'a', &yylval) == YYPUSH_MORE); - assert (yypush_parse (yyps, 'b', &yylval) == YYPUSH_MORE); - yypstate_delete (yyps); +void +yyerror (char const *msg) +{ + fprintf (stderr, "%s\n", msg); +} + +int +yylex (void) +{ + return 0; +} + +int +main (void) +{ + yypstate *ps; + int i; + + for (i = 0; i < 2; ++i) + { + ps = yypstate_new (); + assert (ps); + assert (yypstate_new () == NULL); + ]m4_if([$1], [[both]], [[assert (yyparse () == 2)]])[; + yychar = 0; + assert (yypush_parse (ps) == 0); + assert (yypstate_new () == NULL); + ]m4_if([$1], [[both]], [[assert (yyparse () == 2)]])[; + yypstate_delete (ps); + } return 0; } ]]) -AT_CHECK([[bison -o input.c input.y]]) +AT_BISON_CHECK([[-o input.c input.y]]) AT_COMPILE([[input]]) AT_PARSER_CHECK([[./input]]) +]) + +AT_MULTIPLE_IMPURE_INSTANCES_CHECK([[both]]) +AT_MULTIPLE_IMPURE_INSTANCES_CHECK([[push]]) + +m4_popdef([AT_MULTIPLE_IMPURE_INSTANCES_CHECK]) + +AT_CLEANUP + +## ----------------------- ## +## Unsupported Skeletons. ## +## ----------------------- ## + +AT_SETUP([[Unsupported Skeletons]]) + +AT_DATA([[input.y]], +[[%glr-parser +%define api.push-pull push +%% +start: ; +]]) + +AT_BISON_CHECK([[input.y]], [[1]], [], +[[input.y:2.9-21: %define variable 'api.push-pull' is not used +]]) AT_CLEANUP