diff options
author | Denys Vlasenko | 2021-01-09 08:27:37 +0100 |
---|---|---|
committer | Denys Vlasenko | 2021-05-03 20:06:49 +0200 |
commit | 611bbfc148477aec863454dd85e6f1bfe5770332 (patch) | |
tree | 9e7c92c666a767708ee97119acdadefa43f2262d | |
parent | 23dd1c75b7457f08f1c55a95f3c2fb6faf742562 (diff) | |
download | busybox-611bbfc148477aec863454dd85e6f1bfe5770332.zip busybox-611bbfc148477aec863454dd85e6f1bfe5770332.tar.gz |
ash: fix ${unset_var/pattern/repl}
function old new delta
subevalvar 1349 1353 +4
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | shell/ash.c | 3 | ||||
-rw-r--r-- | shell/ash_test/ash-vars/var_bash_repl_empty_var.right | 1 | ||||
-rwxr-xr-x | shell/ash_test/ash-vars/var_bash_repl_empty_var.tests | 2 |
3 files changed, 5 insertions, 1 deletions
diff --git a/shell/ash.c b/shell/ash.c index ecbfbf0..a33ab06 100644 --- a/shell/ash.c +++ b/shell/ash.c @@ -7011,7 +7011,8 @@ subevalvar(char *start, char *str, int strloc, slash_pos = -1; if (repl) { slash_pos = expdest - ((char *)stackblock() + strloc); - STPUTC('/', expdest); + if (!(flag & EXP_DISCARD)) + STPUTC('/', expdest); //bb_error_msg("repl+1:'%s'", repl + 1); p = argstr(repl + 1, (flag & EXP_DISCARD) | EXP_TILDE); /* EXP_TILDE: echo "${v/x/~}" expands ~ ! */ *repl = '/'; diff --git a/shell/ash_test/ash-vars/var_bash_repl_empty_var.right b/shell/ash_test/ash-vars/var_bash_repl_empty_var.right index 8929167..cf8f088 100644 --- a/shell/ash_test/ash-vars/var_bash_repl_empty_var.right +++ b/shell/ash_test/ash-vars/var_bash_repl_empty_var.right @@ -1,2 +1,3 @@ + Ok:0 diff --git a/shell/ash_test/ash-vars/var_bash_repl_empty_var.tests b/shell/ash_test/ash-vars/var_bash_repl_empty_var.tests index 73a43d3..22aaba5 100755 --- a/shell/ash_test/ash-vars/var_bash_repl_empty_var.tests +++ b/shell/ash_test/ash-vars/var_bash_repl_empty_var.tests @@ -1,3 +1,5 @@ +unset v +echo ${v/*/w} v='' echo ${v/*/w} echo Ok:$? |