diff options
author | Chet Ramey <chet.ramey@case.edu> | 2019-08-29 11:21:20 -0400 |
---|---|---|
committer | Chet Ramey <chet.ramey@case.edu> | 2019-08-29 11:21:20 -0400 |
commit | d894cfd104086ddf68c286e67a5fb2e02eb43b7b (patch) | |
tree | d06e4d571a1b05762799abc584fe0461ca949d7b | |
parent | 6a3116f58c876ca58a786f0ddff578ecf126588e (diff) | |
download | bash-d894cfd104086ddf68c286e67a5fb2e02eb43b7b.tar.gz |
Bash-5.0 patch 11: fix quoted null character removal in operands of conditional ([[) commands
-rw-r--r-- | patchlevel.h | 2 | ||||
-rw-r--r-- | subst.c | 6 |
2 files changed, 6 insertions, 2 deletions
diff --git a/patchlevel.h b/patchlevel.h index 8002af70..772676c8 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 10 +#define PATCHLEVEL 11 #endif /* _PATCHLEVEL_H_ */ @@ -3625,7 +3625,9 @@ remove_backslashes (string) this case, we quote the string specially for the globbing code. If SPECIAL is 2, this is an rhs argument for the =~ operator, and should be quoted appropriately for regcomp/regexec. The caller is responsible - for removing the backslashes if the unquoted word is needed later. */ + for removing the backslashes if the unquoted word is needed later. In + any case, since we don't perform word splitting, we need to do quoted + null character removal. */ char * cond_expand_word (w, special) WORD_DESC *w; @@ -3646,6 +3648,8 @@ cond_expand_word (w, special) { if (special == 0) /* LHS */ { + if (l->word) + word_list_remove_quoted_nulls (l); dequote_list (l); r = string_list (l); } |