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