diff options
author | Peter Stephenson <pws@users.sourceforge.net> | 2003-02-17 11:41:58 +0000 |
---|---|---|
committer | Peter Stephenson <pws@users.sourceforge.net> | 2003-02-17 11:41:58 +0000 |
commit | 40c29457f285deaba4959dd23d5f2dd859ddb956 (patch) | |
tree | eef78ccf4dd50dd9ef37a4a8764e01ebfd9733ce /Src | |
parent | a71bf4a283a5a9ba58ac0057b689c4cee5c9e354 (diff) | |
download | zsh-40c29457f285deaba4959dd23d5f2dd859ddb956.tar.gz zsh-40c29457f285deaba4959dd23d5f2dd859ddb956.tar.xz zsh-40c29457f285deaba4959dd23d5f2dd859ddb956.zip |
18251: Fix select and make it respect EOF
Diffstat (limited to 'Src')
-rw-r--r-- | Src/loop.c | 4 | ||||
-rw-r--r-- | Src/parse.c | 10 |
2 files changed, 9 insertions, 5 deletions
diff --git a/Src/loop.c b/Src/loop.c index 4da5a50f0..ebb07445b 100644 --- a/Src/loop.c +++ b/Src/loop.c @@ -202,7 +202,7 @@ execselect(Estate state, int do_exec) wordcode code = state->pc[-1]; char *str, *s, *name; LinkNode n; - int i, usezle; + int i, usezle, oignoreeof = opts[IGNOREEOF]; FILE *inp; size_t more; LinkList args; @@ -238,6 +238,7 @@ execselect(Estate state, int do_exec) inp = fdopen(dup(usezle ? SHTTY : 0), "r"); more = selectlist(args, 0); loop = state->pc; + opts[IGNOREEOF] = 0; for (;;) { for (;;) { if (empty(bufstack)) { @@ -301,6 +302,7 @@ execselect(Estate state, int do_exec) fclose(inp); loops--; state->pc = end; + opts[IGNOREEOF] = oignoreeof; return lastval; } diff --git a/Src/parse.c b/Src/parse.c index a6c4cd10b..d7aaa9f63 100644 --- a/Src/parse.c +++ b/Src/parse.c @@ -923,18 +923,19 @@ par_for(int *complex) yylex(); type = WC_FOR_COND; } else { - int np, n, posix_in, ona = noaliases, onc = nocorrect; + int np = 0, n, posix_in, ona = noaliases, onc = nocorrect; infor = 0; if (tok != STRING || !isident(tokstr)) YYERRORV(oecused); - np = ecadd(0); + if (!sel) + np = ecadd(0); n = 0; incmdpos = 1; noaliases = nocorrect = 1; for (;;) { n++; ecstr(tokstr); - yylex(); + yylex(); if (tok != STRING || !strcmp(tokstr, "in") || sel) break; if (!isident(tokstr) || errflag) @@ -946,7 +947,8 @@ par_for(int *complex) } noaliases = ona; nocorrect = onc; - ecbuf[np] = n; + if (!sel) + ecbuf[np] = n; posix_in = isnewlin; while (isnewlin) yylex(); |