ash: fix error during recursive processing of here document
authorRon Yorston <rmy@pobox.com>
Thu, 29 Oct 2015 16:44:56 +0000 (16:44 +0000)
committerMike Frysinger <vapier@gentoo.org>
Mon, 21 Mar 2016 18:28:06 +0000 (14:28 -0400)
Save the value of the checkkwd flag to prevent it being clobbered
during recursion.

Based on commit ec2c84d from git://git.kernel.org/pub/scm/utils/dash/dash.git
by Herbert Xu.

function                                             old     new   delta
readtoken                                            190     203     +13
------------------------------------------------------------------------------
(add/remove: 0/0 grow/shrink: 1/0 up/down: 13/0)               Total: 13 bytes

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 713f07d906d9171953be0c12e2369869855b6ca6)

shell/ash.c
shell/ash_test/ash-heredoc/heredoc3.right [new file with mode: 0644]
shell/ash_test/ash-heredoc/heredoc3.tests [new file with mode: 0755]

index 8a1628e81f3c8826e3a1cb97b35e28f40aac8c41..256e933e32e250464d88d41b4188c11c2204344c 100644 (file)
@@ -11893,6 +11893,7 @@ static int
 readtoken(void)
 {
        int t;
+       int kwd = checkkwd;
 #if DEBUG
        smallint alreadyseen = tokpushback;
 #endif
@@ -11906,7 +11907,7 @@ readtoken(void)
        /*
         * eat newlines
         */
-       if (checkkwd & CHKNL) {
+       if (kwd & CHKNL) {
                while (t == TNL) {
                        parseheredoc();
                        t = xxreadtoken();
@@ -11920,7 +11921,7 @@ readtoken(void)
        /*
         * check for keywords
         */
-       if (checkkwd & CHKKWD) {
+       if (kwd & CHKKWD) {
                const char *const *pp;
 
                pp = findkwd(wordtext);
diff --git a/shell/ash_test/ash-heredoc/heredoc3.right b/shell/ash_test/ash-heredoc/heredoc3.right
new file mode 100644 (file)
index 0000000..ce01362
--- /dev/null
@@ -0,0 +1 @@
+hello
diff --git a/shell/ash_test/ash-heredoc/heredoc3.tests b/shell/ash_test/ash-heredoc/heredoc3.tests
new file mode 100755 (executable)
index 0000000..96c227c
--- /dev/null
@@ -0,0 +1,9 @@
+echo hello >greeting
+cat <<EOF &&
+$(cat greeting)
+EOF
+{
+       echo $?
+       cat greeting
+} >/dev/null
+rm greeting