Revert "ash: fix a SEGV case in an invalid heredoc" xxx
authorRon Yorston <rmy@pobox.com>
Thu, 29 Oct 2015 11:30:22 +0000 (11:30 +0000)
committerMike Frysinger <vapier@gentoo.org>
Tue, 22 Mar 2016 22:21:28 +0000 (18:21 -0400)
This reverts commit 7e66102f762a7d80715f0c7e5925433256b78cee but
leaves the test in place as it's still valid.

Reported-by: Natanael Copa <ncopa@alpinelinux.org>
Signed-off-by: Ron Yorston <rmy@pobox.com>
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
(cherry picked from commit 6bd2fabc52fa76b69a65772878e2e745c0fff3ff)

shell/ash.c

index 96aa2a223d34e4de2a7f5f20d339246e3ab44404..48b7c4f3f28a051b28ead972c00607ad9b9443d6 100644 (file)
@@ -10518,7 +10518,7 @@ static union node *andor(void);
 static union node *pipeline(void);
 static union node *parse_command(void);
 static void parseheredoc(void);
-static char nexttoken_ends_list(void);
+static char peektoken(void);
 static int readtoken(void);
 
 static union node *
@@ -10528,7 +10528,7 @@ list(int nlflag)
        int tok;
 
        checkkwd = CHKNL | CHKKWD | CHKALIAS;
-       if (nlflag == 2 && nexttoken_ends_list())
+       if (nlflag == 2 && peektoken())
                return NULL;
        n1 = NULL;
        for (;;) {
@@ -10570,15 +10570,8 @@ list(int nlflag)
                                tokpushback = 1;
                        }
                        checkkwd = CHKNL | CHKKWD | CHKALIAS;
-                       if (nexttoken_ends_list()) {
-                               /* Testcase: "<<EOF; then <W".
-                                * It used to segfault w/o this check:
-                                */
-                               if (heredoclist) {
-                                       raise_error_unexpected_syntax(-1);
-                               }
+                       if (peektoken())
                                return n1;
-                       }
                        break;
                case TEOF:
                        if (heredoclist)
@@ -11958,7 +11951,7 @@ readtoken(void)
 }
 
 static char
-nexttoken_ends_list(void)
+peektoken(void)
 {
        int t;