Petr Šabata 33fc6c
From ddf3f643cb9b9a2ca8e6d996c605e4332204874c Mon Sep 17 00:00:00 2001
Petr Šabata 33fc6c
From: Chet Ramey <chet.ramey@case.edu>
Petr Šabata 33fc6c
Date: Fri, 18 Jan 2019 15:13:57 -0500
Petr Šabata 33fc6c
Subject: [PATCH] Bash-5.0 patch 2: fix expansion of aliases whose value ends
Petr Šabata 33fc6c
 with an unquoted tab
Petr Šabata 33fc6c
Petr Šabata 33fc6c
---
Petr Šabata 33fc6c
 parse.y      | 5 ++++-
Petr Šabata 33fc6c
 parser.h     | 1 +
Petr Šabata 33fc6c
 patchlevel.h | 2 +-
Petr Šabata 33fc6c
 y.tab.c      | 5 ++++-
Petr Šabata 33fc6c
 4 files changed, 10 insertions(+), 3 deletions(-)
Petr Šabata 33fc6c
Petr Šabata 33fc6c
diff --git a/parse.y b/parse.y
Petr Šabata 33fc6c
index 3ff87bcc..07e6e3e4 100644
Petr Šabata 33fc6c
--- a/parse.y
Petr Šabata 33fc6c
+++ b/parse.y
Petr Šabata 33fc6c
@@ -2557,12 +2557,14 @@ next_alias_char:
Petr Šabata 33fc6c
   if (uc == 0 && pushed_string_list && pushed_string_list->flags != PSH_SOURCE &&
Petr Šabata 33fc6c
       pushed_string_list->flags != PSH_DPAREN &&
Petr Šabata 33fc6c
       (parser_state & PST_COMMENT) == 0 &&
Petr Šabata 33fc6c
+      (parser_state & PST_ENDALIAS) == 0 &&	/* only once */
Petr Šabata 33fc6c
       shell_input_line_index > 0 &&
Petr Šabata 33fc6c
-      shell_input_line[shell_input_line_index-1] != ' ' &&
Petr Šabata 33fc6c
+      shellblank (shell_input_line[shell_input_line_index-1]) == 0 &&
Petr Šabata 33fc6c
       shell_input_line[shell_input_line_index-1] != '\n' &&
Petr Šabata 33fc6c
       shellmeta (shell_input_line[shell_input_line_index-1]) == 0 &&
Petr Šabata 33fc6c
       (current_delimiter (dstack) != '\'' && current_delimiter (dstack) != '"'))
Petr Šabata 33fc6c
     {
Petr Šabata 33fc6c
+      parser_state |= PST_ENDALIAS;
Petr Šabata 33fc6c
       return ' ';	/* END_ALIAS */
Petr Šabata 33fc6c
     }
Petr Šabata 33fc6c
 #endif
Petr Šabata 33fc6c
@@ -2571,6 +2573,7 @@ pop_alias:
Petr Šabata 33fc6c
   /* This case works for PSH_DPAREN as well */
Petr Šabata 33fc6c
   if (uc == 0 && pushed_string_list && pushed_string_list->flags != PSH_SOURCE)
Petr Šabata 33fc6c
     {
Petr Šabata 33fc6c
+      parser_state &= ~PST_ENDALIAS;
Petr Šabata 33fc6c
       pop_string ();
Petr Šabata 33fc6c
       uc = shell_input_line[shell_input_line_index];
Petr Šabata 33fc6c
       if (uc)
Petr Šabata 33fc6c
diff --git a/parser.h b/parser.h
Petr Šabata 33fc6c
index 54dd2c88..6d08915d 100644
Petr Šabata 33fc6c
--- a/parser.h
Petr Šabata 33fc6c
+++ b/parser.h
Petr Šabata 33fc6c
@@ -47,6 +47,7 @@
Petr Šabata 33fc6c
 #define PST_REPARSE	0x040000	/* re-parsing in parse_string_to_word_list */
Petr Šabata 33fc6c
 #define PST_REDIRLIST	0x080000	/* parsing a list of redirections preceding a simple command name */
Petr Šabata 33fc6c
 #define PST_COMMENT	0x100000	/* parsing a shell comment; used by aliases */
Petr Šabata 33fc6c
+#define PST_ENDALIAS	0x200000	/* just finished expanding and consuming an alias */
Petr Šabata 33fc6c
 
Petr Šabata 33fc6c
 /* Definition of the delimiter stack.  Needed by parse.y and bashhist.c. */
Petr Šabata 33fc6c
 struct dstack {
Petr Šabata 33fc6c
diff --git a/patchlevel.h b/patchlevel.h
Petr Šabata 33fc6c
index 40db1a32..a988d852 100644
Petr Šabata 33fc6c
--- a/patchlevel.h
Petr Šabata 33fc6c
+++ b/patchlevel.h
Petr Šabata 33fc6c
@@ -25,6 +25,6 @@
Petr Šabata 33fc6c
    regexp `^#define[ 	]*PATCHLEVEL', since that's what support/mkversion.sh
Petr Šabata 33fc6c
    looks for to find the patch level (for the sccs version string). */
Petr Šabata 33fc6c
 
Petr Šabata 33fc6c
-#define PATCHLEVEL 1
Petr Šabata 33fc6c
+#define PATCHLEVEL 2
Petr Šabata 33fc6c
 
Petr Šabata 33fc6c
 #endif /* _PATCHLEVEL_H_ */
Petr Šabata 33fc6c
diff --git a/y.tab.c b/y.tab.c
Petr Šabata 33fc6c
index 1abe2c50..7efce3c8 100644
Petr Šabata 33fc6c
--- a/y.tab.c
Petr Šabata 33fc6c
+++ b/y.tab.c
Petr Šabata 33fc6c
@@ -4873,12 +4873,14 @@ next_alias_char:
Petr Šabata 33fc6c
   if (uc == 0 && pushed_string_list && pushed_string_list->flags != PSH_SOURCE &&
Petr Šabata 33fc6c
       pushed_string_list->flags != PSH_DPAREN &&
Petr Šabata 33fc6c
       (parser_state & PST_COMMENT) == 0 &&
Petr Šabata 33fc6c
+      (parser_state & PST_ENDALIAS) == 0 &&	/* only once */
Petr Šabata 33fc6c
       shell_input_line_index > 0 &&
Petr Šabata 33fc6c
-      shell_input_line[shell_input_line_index-1] != ' ' &&
Petr Šabata 33fc6c
+      shellblank (shell_input_line[shell_input_line_index-1]) == 0 &&
Petr Šabata 33fc6c
       shell_input_line[shell_input_line_index-1] != '\n' &&
Petr Šabata 33fc6c
       shellmeta (shell_input_line[shell_input_line_index-1]) == 0 &&
Petr Šabata 33fc6c
       (current_delimiter (dstack) != '\'' && current_delimiter (dstack) != '"'))
Petr Šabata 33fc6c
     {
Petr Šabata 33fc6c
+      parser_state |= PST_ENDALIAS;
Petr Šabata 33fc6c
       return ' ';	/* END_ALIAS */
Petr Šabata 33fc6c
     }
Petr Šabata 33fc6c
 #endif
Petr Šabata 33fc6c
@@ -4887,6 +4889,7 @@ pop_alias:
Petr Šabata 33fc6c
   /* This case works for PSH_DPAREN as well */
Petr Šabata 33fc6c
   if (uc == 0 && pushed_string_list && pushed_string_list->flags != PSH_SOURCE)
Petr Šabata 33fc6c
     {
Petr Šabata 33fc6c
+      parser_state &= ~PST_ENDALIAS;
Petr Šabata 33fc6c
       pop_string ();
Petr Šabata 33fc6c
       uc = shell_input_line[shell_input_line_index];
Petr Šabata 33fc6c
       if (uc)
Petr Šabata 33fc6c
-- 
Petr Šabata 33fc6c
2.17.2
Petr Šabata 33fc6c