summaryrefslogtreecommitdiff
path: root/shell/hush.c
diff options
context:
space:
mode:
authorDenys Vlasenko2011-05-31 17:35:45 +0200
committerDenys Vlasenko2011-05-31 17:35:45 +0200
commit00ae989ee5b57593362405288b5e977551cafb0b (patch)
tree57d93dd050c292dbec819b166fd22f26fa21172c /shell/hush.c
parent14f55538f07f0b1493c713d84a046b9022fcf8fb (diff)
downloadbusybox-00ae989ee5b57593362405288b5e977551cafb0b.zip
busybox-00ae989ee5b57593362405288b5e977551cafb0b.tar.gz
hush: fix a corner case of empty "do \n done" structure
The structure is: while cmd; do done bash doesn't accept it at all. We were accepting it but execution was buggy. Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'shell/hush.c')
-rw-r--r--shell/hush.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/shell/hush.c b/shell/hush.c
index c3a4afb..c7971b0 100644
--- a/shell/hush.c
+++ b/shell/hush.c
@@ -7498,7 +7498,10 @@ static int run_list(struct pipe *pi)
#endif
#if ENABLE_HUSH_LOOPS
/* Beware of "while false; true; do ..."! */
- if (pi->next && pi->next->res_word == RES_DO) {
+ if (pi->next
+ && (pi->next->res_word == RES_DO || pi->next->res_word == RES_DONE)
+ /* (the second check above is needed for "while ...; do \n done" case) */
+ ) {
if (rword == RES_WHILE) {
if (rcode) {
/* "while false; do...done" - exitcode 0 */