ash: fix a SEGV case in an invalid heredoc
authorDenys Vlasenko <vda.linux@googlemail.com>
Thu, 5 Feb 2015 20:00:17 +0000 (21:00 +0100)
committerDenys Vlasenko <vda.linux@googlemail.com>
Thu, 5 Feb 2015 20:00:17 +0000 (21:00 +0100)
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
shell/ash.c
shell/ash_test/ash-heredoc/heredoc1.right [new file with mode: 0644]
shell/ash_test/ash-heredoc/heredoc1.tests [new file with mode: 0755]

index c5ad96909f3387cdeb840fad49e2b1e5c5b6fa9d..0f9f73ec369825108b1040ed45d4956f8cb53db6 100644 (file)
@@ -10556,7 +10556,7 @@ static union node *andor(void);
 static union node *pipeline(void);
 static union node *parse_command(void);
 static void parseheredoc(void);
-static char peektoken(void);
+static char nexttoken_ends_list(void);
 static int readtoken(void);
 
 static union node *
@@ -10566,7 +10566,7 @@ list(int nlflag)
        int tok;
 
        checkkwd = CHKNL | CHKKWD | CHKALIAS;
-       if (nlflag == 2 && peektoken())
+       if (nlflag == 2 && nexttoken_ends_list())
                return NULL;
        n1 = NULL;
        for (;;) {
@@ -10608,8 +10608,15 @@ list(int nlflag)
                                tokpushback = 1;
                        }
                        checkkwd = CHKNL | CHKKWD | CHKALIAS;
-                       if (peektoken())
+                       if (nexttoken_ends_list()) {
+                               /* Testcase: "<<EOF; then <W".
+                                * It used to segfault w/o this check:
+                                */
+                               if (heredoclist) {
+                                       raise_error_unexpected_syntax(-1);
+                               }
                                return n1;
+                       }
                        break;
                case TEOF:
                        if (heredoclist)
@@ -12046,7 +12053,7 @@ readtoken(void)
 }
 
 static char
-peektoken(void)
+nexttoken_ends_list(void)
 {
        int t;
 
diff --git a/shell/ash_test/ash-heredoc/heredoc1.right b/shell/ash_test/ash-heredoc/heredoc1.right
new file mode 100644 (file)
index 0000000..895f5ee
--- /dev/null
@@ -0,0 +1 @@
+heredoc1.tests: line 3: syntax error: unexpected "then"
diff --git a/shell/ash_test/ash-heredoc/heredoc1.tests b/shell/ash_test/ash-heredoc/heredoc1.tests
new file mode 100755 (executable)
index 0000000..a912a67
--- /dev/null
@@ -0,0 +1,3 @@
+# We used to SEGV on this:
+
+<<EOF; then <W