X-Git-Url: https://diplodocus.org/git/nmh/blobdiff_plain/00cfba08b276c3566cdc7d268965a6fc80c441df..f1595ee7fc4db1bf8c50b00a796fb3f9b1d66c21:/uip/pick.c diff --git a/uip/pick.c b/uip/pick.c index fba190a2..9b2e0cde 100644 --- a/uip/pick.c +++ b/uip/pick.c @@ -66,9 +66,10 @@ main (int argc, char **argv) struct msgs_array msgs = { 0, 0, NULL }; struct msgnum_array nums = { 0, 0, NULL }; struct msgs *mp, *mp2; - register FILE *fp; + FILE *fp; int debug = 0; int reverse = 0; + int start, end, inc; if (nmh_init(argv[0], 1)) { return 1; } @@ -237,9 +238,16 @@ main (int argc, char **argv) * match. If there is NOT a match, then add it to a list to * remove from the final sequence (it will make sense later) */ - for (msgnum = reverse ? mp->hghsel : mp->lowsel; - reverse ? msgnum >= mp->lowsel : msgnum <= mp->hghsel; - msgnum += reverse ? -1 : 1) { + if (!reverse) { /* Overflow or underflow is fine. */ + start = mp->lowsel; + end = mp->hghsel + 1; + inc = 1; + } else { + start = mp->hghsel; + end = mp->lowsel - 1; + inc = -1; + } + for (msgnum = start; msgnum != end; msgnum += inc) { if (is_selected (mp, msgnum)) { if ((fp = fopen (cp = m_name (msgnum), "r")) == NULL) admonish (cp, "unable to read message");