]> git.saurik.com Git - bison.git/commitdiff
(yyreturn): Don't pop stack if yyinitStateSet failed,
authorPaul Eggert <eggert@cs.ucla.edu>
Wed, 20 Jul 2005 21:43:32 +0000 (21:43 +0000)
committerPaul Eggert <eggert@cs.ucla.edu>
Wed, 20 Jul 2005 21:43:32 +0000 (21:43 +0000)
as the stack isn't valid in that case.

data/glr.c

index 578ad1163318d5ba57c0d2ee57a1697fd9c2534c..219dd3f57620c2a4b5a9c6ed724d337609038509 100644 (file)
@@ -2107,17 +2107,21 @@ b4_syncline([@oline@], [@ofile@])])dnl
                 yytoken, yylvalp]b4_location_if([, yyllocp])[);
 
   /* Now pop stack until empty, destroying its entries as we go.  */
-  while (yystack.yytops.yystates[0] != NULL)
-    {
-      yyGLRState *yys = yystack.yytops.yystates[0];
-]b4_location_if([[      yystack.yyerror_range[1].yystate.yyloc = yys->yyloc;]])[
-      yydestruct ("Error: popping",
-                 yystos[yys->yylrState],
-                 &yys->yysemantics.yysval]b4_location_if([, &yys->yyloc])[);
-      yystack.yytops.yystates[0] = yys->yypred;
-      yystack.yynextFree -= 1;
-      yystack.yyspaceLeft += 1;
-    }
+  {
+    yyGLRState** yystates = yystack.yytops.yystates;
+    if (yystates)
+      while (yystates[0])
+       {
+         yyGLRState *yys = yystates[0];
+]b4_location_if([[       yystack.yyerror_range[1].yystate.yyloc = yys->yyloc;]]
+)[       yydestruct ("Error: popping",
+                     yystos[yys->yylrState],
+                     &yys->yysemantics.yysval]b4_location_if([, &yys->yyloc])[);
+         yystates[0] = yys->yypred;
+         yystack.yynextFree -= 1;
+         yystack.yyspaceLeft += 1;
+       }
+  }
 
   yyfreeGLRStack (&yystack);
   return yyresult;