From: Ron Yorston Date: Mon, 29 Jul 2019 08:51:14 +0000 (+0100) Subject: ash: only catch unexpected exceptions in PS1 expansion X-Git-Tag: 1_31_1~11 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=c88d3ec458e66d8c25af81ae7b2044933c069563;p=oweals%2Fbusybox.git ash: only catch unexpected exceptions in PS1 expansion Commit d1a2fa2a4 (ash: catch error in arithmetic expansion in PS1) catches all exceptions raised by expandarg(). Some exceptions, such as the EXEXIT raised when command expansion is used, are expected: export PS1='$(echo "$ ")' These should be processed normally or the shell hangs at the prompt. function old new delta expandstr 344 353 +9 ------------------------------------------------------------------------------ (add/remove: 0/0 grow/shrink: 1/0 up/down: 9/0) Total: 9 bytes Signed-off-by: Ron Yorston Signed-off-by: Denys Vlasenko --- diff --git a/shell/ash.c b/shell/ash.c index e3bbac9a0..c0352602b 100644 --- a/shell/ash.c +++ b/shell/ash.c @@ -13126,6 +13126,8 @@ expandstr(const char *ps, int syntax_type) if (setjmp(jmploc.loc) == 0) { exception_handler = &jmploc; expandarg(&n, NULL, EXP_QUOTED); + } else if (exception_type == EXEXIT) { + exitshell(); } exception_handler = savehandler; RESTORE_INT(saveint);