Author: jilles
Date: Wed Sep  2 19:49:55 2015
New Revision: 287408
URL: https://svnweb.freebsd.org/changeset/base/287408

Log:
  sh: Allow empty << EOF markers.

Added:
  head/bin/sh/tests/parser/heredoc13.0   (contents, props changed)
Modified:
  head/bin/sh/parser.c
  head/bin/sh/tests/parser/Makefile

Modified: head/bin/sh/parser.c
==============================================================================
--- head/bin/sh/parser.c        Wed Sep  2 18:51:36 2015        (r287407)
+++ head/bin/sh/parser.c        Wed Sep  2 19:49:55 2015        (r287408)
@@ -106,6 +106,8 @@ static int startlinno;              /* line # where 
 static int funclinno;          /* line # where the current function started */
 static struct parser_temp *parser_temp;
 
+#define NOEOFMARK ((const char *)&heredoclist)
+
 
 static union node *list(int);
 static union node *andor(void);
@@ -972,6 +974,10 @@ checkend(int c, const char *eofmark, int
                        pungetc();
                        pushstring(eofmark + 1, q - (eofmark + 1), NULL);
                }
+       } else if (c == '\n' && *eofmark == '\0') {
+               c = PEOF;
+               plinno++;
+               needprompt = doprompt;
        }
        return (c);
 }
@@ -1383,7 +1389,7 @@ readtoken1(int firstc, char const *initi
 
        STARTSTACKSTR(out);
        loop: { /* for each line, until end of word */
-               if (eofmark)
+               if (eofmark && eofmark != NOEOFMARK)
                        /* set c to PEOF if at end of here document */
                        c = checkend(c, eofmark, striptabs);
                for (;;) {      /* until end of line or end of word */
@@ -2046,7 +2052,7 @@ expandstr(const char *ps)
                parser_temp = NULL;
                setinputstring(ps, 1);
                doprompt = 0;
-               readtoken1(pgetc(), DQSYNTAX, "", 0);
+               readtoken1(pgetc(), DQSYNTAX, NOEOFMARK, 0);
                if (backquotelist != NULL)
                        error("Command substitution not allowed here");
 

Modified: head/bin/sh/tests/parser/Makefile
==============================================================================
--- head/bin/sh/tests/parser/Makefile   Wed Sep  2 18:51:36 2015        
(r287407)
+++ head/bin/sh/tests/parser/Makefile   Wed Sep  2 19:49:55 2015        
(r287408)
@@ -57,6 +57,7 @@ FILES+=               heredoc9.0
 FILES+=                heredoc10.0
 FILES+=                heredoc11.0
 FILES+=                heredoc12.0
+FILES+=                heredoc13.0
 FILES+=                line-cont1.0
 FILES+=                line-cont2.0
 FILES+=                line-cont3.0

Added: head/bin/sh/tests/parser/heredoc13.0
==============================================================================
--- /dev/null   00:00:00 1970   (empty, because file is newly added)
+++ head/bin/sh/tests/parser/heredoc13.0        Wed Sep  2 19:49:55 2015        
(r287408)
@@ -0,0 +1,21 @@
+# $FreeBSD$
+
+failures=0
+
+check() {
+       if ! eval "[ $* ]"; then
+               echo "Failed: $*"
+               : $((failures += 1))
+       fi
+}
+
+check '"$(cat <<""
+
+echo yes)" = "yes"'
+
+check '"$(cat <<""
+yes
+
+)" = "yes"'
+
+exit $((failures != 0))
_______________________________________________
svn-src-head@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-head
To unsubscribe, send any mail to "svn-src-head-unsubscr...@freebsd.org"

Reply via email to