summaryrefslogtreecommitdiff
path: root/Src/loop.c
diff options
context:
space:
mode:
Diffstat (limited to 'Src/loop.c')
-rw-r--r--Src/loop.c20
1 files changed, 15 insertions, 5 deletions
diff --git a/Src/loop.c b/Src/loop.c
index 90a0761b3..2f639fd5a 100644
--- a/Src/loop.c
+++ b/Src/loop.c
@@ -73,7 +73,7 @@ execfor(Estate state, int do_exec)
matheval(str);
if (errflag) {
state->pc = end;
- return lastval = errflag;
+ return 1;
}
cond = ecgetstr(state, EC_NODUP, &ctok);
advance = ecgetstr(state, EC_NODUP, &atok);
@@ -87,8 +87,13 @@ execfor(Estate state, int do_exec)
state->pc = end;
return 0;
}
- if (htok)
+ if (htok) {
execsubst(args);
+ if (errflag) {
+ state->pc = end;
+ return 1;
+ }
+ }
} else {
char **x;
@@ -97,7 +102,7 @@ execfor(Estate state, int do_exec)
addlinknode(args, dupstring(*x));
}
}
- lastval = 0;
+ /* lastval = 0; */
loops++;
pushheap();
cmdpush(CS_FOR);
@@ -223,15 +228,20 @@ execselect(Estate state, UNUSED(int do_exec))
state->pc = end;
return 0;
}
- if (htok)
+ if (htok) {
execsubst(args);
+ if (errflag) {
+ state->pc = end;
+ return 1;
+ }
+ }
}
if (!args || empty(args)) {
state->pc = end;
return 1;
}
loops++;
- lastval = 0;
+ /* lastval = 0; */
pushheap();
cmdpush(CS_SELECT);
usezle = interact && SHTTY != -1 && isset(USEZLE);