summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorP. J. McDermott <pj@pehjota.net>2016-02-21 02:27:48 (EST)
committer P. J. McDermott <pj@pehjota.net>2016-02-21 02:27:48 (EST)
commit33554a524c8fda86e8d41cc91f8e992ef09b0555 (patch)
treed3cf698fb2d38bec2e061d88375b62db181df83e
parente638323c7a0cbe79c390cef5fdf1a37a640e304c (diff)
downloadeggshell-33554a524c8fda86e8d41cc91f8e992ef09b0555.zip
eggshell-33554a524c8fda86e8d41cc91f8e992ef09b0555.tar.gz
eggshell-33554a524c8fda86e8d41cc91f8e992ef09b0555.tar.bz2
Fix handling of multiple here-documents on a line
-rw-r--r--parsing/lexer.sh80
-rw-r--r--parsing/parse.sh9
2 files changed, 44 insertions, 45 deletions
diff --git a/parsing/lexer.sh b/parsing/lexer.sh
index c88c8b6..dc0b48d 100644
--- a/parsing/lexer.sh
+++ b/parsing/lexer.sh
@@ -4,7 +4,7 @@ ln_off=
start=
c=
wordexp=
-here_stack=
+here_queue=
here_awaiting_end=
here_awaiting_word=
tok=
@@ -70,12 +70,10 @@ lgetc()
next()
{
- case "${here_stack}" in *"${RS}"*)
- if ${here_awaiting_word}; then
- next_here
- return
- fi
- esac
+ if ${here_awaiting_word}; then
+ next_here
+ return
+ fi
while :; do
dbg "parsing char '$c' at lineno $lineno"
case "${c}" in
@@ -85,15 +83,12 @@ next()
return
;;
"${LF}")
- case "${here_stack}" in *"${RS}"*)
- if ${here_awaiting_end}; then
- synexp ''
- else
- here_awaiting_end=false
- here_awaiting_word=true
- fi
- ;;
- esac
+ if ${here_awaiting_end}; then
+ synexp ''
+ else
+ here_awaiting_end=false
+ here_awaiting_word=true
+ fi
lgetc
lineno=$((${lineno} + 1))
tok=T_NEWLINE
@@ -193,14 +188,20 @@ next_here()
local res=
local wordexp=
- # Pop the here-document off of the stack.
- here="${here_stack##*${RS}}"
+ # Dequeue the here-document.
+ here="${here_queue%%${RS}*}"
here_strip_tabs="${here%%${US}*}"
here_end="${here%${US}*}"
here_end="${here_end#*${US}}"
here_escaped="${here##*${US}}"
- here_stack="${here_stack%${RS}*}"
- here_awaiting_word=false
+ here_queue="${here_queue#*${RS}}"
+ case "${here_queue}" in
+ *"${RS}"*)
+ ;;
+ *)
+ here_awaiting_word=false
+ ;;
+ esac
line=''
word=''
@@ -276,15 +277,14 @@ next_io()
case "${c}" in '-')
lgetc
tok=T_DLESSDASH
- here_stack="${here_stack}${RS}"
- here_stack="${here_stack}true"
+ here_queue="${here_queue}true"
here_awaiting_end=true
here_awaiting_word=false
break
;;
esac
tok=T_DLESS
- here_stack="${here_stack}${RS}false"
+ here_queue="${here_queue}false"
here_awaiting_end=true
here_awaiting_word=false
break
@@ -346,21 +346,19 @@ next_word()
lineno=$((${lineno} + ${ln_off}))
tok="T_WORD${US}${word}"
- case "${here_stack}" in *"${RS}"*)
- if ${here_awaiting_end}; then
- here_stack="${here_stack}${US}${word}"
- case "${word}" in
- *\\*|*'"'*|*"'"*)
- here_stack="${here_stack}${US}true"
- ;;
- *)
- here_stack="${here_stack}${US}false"
- ;;
- esac
- here_awaiting_end=false
- fi
- ;;
- esac
+ if ${here_awaiting_end}; then
+ here_queue="${here_queue}${US}${word}"
+ case "${word}" in
+ *\\*|*'"'*|*"'"*)
+ here_queue="${here_queue}${US}true"
+ ;;
+ *)
+ here_queue="${here_queue}${US}false"
+ ;;
+ esac
+ here_queue="${here_queue}${RS}"
+ here_awaiting_end=false
+ fi
}
#
@@ -400,7 +398,7 @@ scan_word()
word="${word}${c}"
;;
'$')
- case "${here_stack}" in *"${RS}"*)
+ case "${here_queue}" in *"${RS}"*)
if ${here_awaiting_end}; then
synerr '%s %s %s %s' \
'Word expansions' \
@@ -879,7 +877,7 @@ run_sublexer()
fname="${fn}"
lineno=${ln}
start="${st}"
- here_stack="${US}"
+ here_queue=''
here_awaiting_end=false
here_awaiting_word=false
tokens=''
@@ -912,7 +910,7 @@ run_lexer()
fname="${fn}"
lineno=1
start="${st}"
- here_stack="${US}"
+ here_queue=''
here_awaiting_end=false
here_awaiting_word=false
tokens=''
diff --git a/parsing/parse.sh b/parsing/parse.sh
index 81b8a54..cbe4dd9 100644
--- a/parsing/parse.sh
+++ b/parsing/parse.sh
@@ -653,7 +653,8 @@ try()
#try '$((1 + (1 + 1)))'
#try '$((1 + $(foo) + 1))'
#try '$((1'
-try 'foo <<EOF' 'bar' 'EOF'
-try 'foo <<-EOF' "${HT}bar" "${HT}EOF"
-try 'foo <<EOF' '$(bar)' 'EOF'
-try 'foo <<E"O"F' '$(bar)' 'E"O"F' # BUG
+#try 'foo <<EOF' 'bar' 'EOF'
+#try 'foo <<-EOF' "${HT}bar" "${HT}EOF"
+#try 'foo <<EOF' '$(bar)' 'EOF'
+#try 'foo <<E"O"F' '$(bar)' 'E"O"F' # BUG
+try 'foo <<EOF1; bar <<EOF2' 'baz' 'EOF1' 'qux' 'EOF2'