From daefb2c5197a17116586b411cd3f12d249cf4e4f Mon Sep 17 00:00:00 2001 From: Chet Ramey Date: Fri, 1 Aug 2014 15:30:48 -0400 Subject: [PATCH] Bash-4.3 patch 20 --- parse.y | 4 +++- patchlevel.h | 2 +- shell.h | 3 ++- y.tab.c | 4 +++- 4 files changed, 9 insertions(+), 4 deletions(-) diff --git a/parse.y b/parse.y index 91bf3bf..cd3cf1e 100644 --- a/parse.y +++ b/parse.y @@ -2642,7 +2642,7 @@ gather_here_documents () int r; r = 0; - while (need_here_doc) + while (need_here_doc > 0) { parser_state |= PST_HEREDOC; make_here_document (redir_stack[r++], line_number); @@ -6075,6 +6075,7 @@ save_parser_state (ps) ps->expand_aliases = expand_aliases; ps->echo_input_at_read = echo_input_at_read; + ps->need_here_doc = need_here_doc; ps->token = token; ps->token_buffer_size = token_buffer_size; @@ -6123,6 +6124,7 @@ restore_parser_state (ps) expand_aliases = ps->expand_aliases; echo_input_at_read = ps->echo_input_at_read; + need_here_doc = ps->need_here_doc; FREE (token); token = ps->token; diff --git a/patchlevel.h b/patchlevel.h index 0a57e4b..6b5f365 100644 --- a/patchlevel.h +++ b/patchlevel.h @@ -25,6 +25,6 @@ regexp `^#define[ ]*PATCHLEVEL', since that's what support/mkversion.sh looks for to find the patch level (for the sccs version string). */ -#define PATCHLEVEL 19 +#define PATCHLEVEL 20 #endif /* _PATCHLEVEL_H_ */ diff --git a/shell.h b/shell.h index 243e467..d63dce8 100644 --- a/shell.h +++ b/shell.h @@ -168,7 +168,8 @@ typedef struct _sh_parser_state_t { /* flags state affecting the parser */ int expand_aliases; int echo_input_at_read; - + int need_here_doc; + } sh_parser_state_t; typedef struct _sh_input_line_state_t { diff --git a/y.tab.c b/y.tab.c index 80fe930..8f7f96e 100644 --- a/y.tab.c +++ b/y.tab.c @@ -4954,7 +4954,7 @@ gather_here_documents () int r; r = 0; - while (need_here_doc) + while (need_here_doc > 0) { parser_state |= PST_HEREDOC; make_here_document (redir_stack[r++], line_number); @@ -8387,6 +8387,7 @@ save_parser_state (ps) ps->expand_aliases = expand_aliases; ps->echo_input_at_read = echo_input_at_read; + ps->need_here_doc = need_here_doc; ps->token = token; ps->token_buffer_size = token_buffer_size; @@ -8435,6 +8436,7 @@ restore_parser_state (ps) expand_aliases = ps->expand_aliases; echo_input_at_read = ps->echo_input_at_read; + need_here_doc = ps->need_here_doc; FREE (token); token = ps->token; -- 2.7.4