diff options
author | mikeh <mikeh@FreeBSD.org> | 2002-06-25 05:28:32 +0000 |
---|---|---|
committer | mikeh <mikeh@FreeBSD.org> | 2002-06-25 05:28:32 +0000 |
commit | 94e2e299e42e15276cab292210f3ecf041a3e28b (patch) | |
tree | 0a4568460101b434b7ba283450e76624c5b40be7 /usr.bin/mail | |
parent | 92912abb162c809019c1c1d0f16c01be2d8be533 (diff) | |
download | FreeBSD-src-94e2e299e42e15276cab292210f3ecf041a3e28b.zip FreeBSD-src-94e2e299e42e15276cab292210f3ecf041a3e28b.tar.gz |
Use strcasestr() instead of reimplementing it.
Diffstat (limited to 'usr.bin/mail')
-rw-r--r-- | usr.bin/mail/list.c | 63 |
1 files changed, 18 insertions, 45 deletions
diff --git a/usr.bin/mail/list.c b/usr.bin/mail/list.c index cfe493e..5eacfb5 100644 --- a/usr.bin/mail/list.c +++ b/usr.bin/mail/list.c @@ -669,21 +669,14 @@ matchsender(str, mesg) char *str; int mesg; { - char *cp, *cp2, *backup; + char *cp; - if (*str == '\0') /* null string matches nothing instead of everything */ + /* null string matches nothing instead of everything */ + if (*str == '\0') return (0); - backup = cp2 = nameof(&message[mesg - 1], 0); - cp = str; - while (*cp2 != '\0') { - if (*cp == '\0') - return (1); - if (toupper((unsigned char)*cp++) != toupper((unsigned char)*cp2++)) { - cp2 = ++backup; - cp = str; - } - } - return (*cp == '\0'); + + cp = nameof(&message[mesg - 1], 0); + return (strcasestr(cp, str) != NULL); } /* @@ -699,7 +692,7 @@ matchto(str, mesg) int mesg; { struct message *mp; - char *cp, *cp2, *backup, **to; + char *cp, **to; str++; @@ -710,21 +703,9 @@ matchto(str, mesg) mp = &message[mesg - 1]; for (to = to_fields; *to != NULL; to++) { - cp = str; - cp2 = hfield(*to, mp); - if (cp2 != NULL) { - backup = cp2; - while (*cp2 != '\0') { - if (*cp == '\0') - return (1); - if (toupper((unsigned char)*cp++) != toupper((unsigned char)*cp2++)) { - cp2 = ++backup; - cp = str; - } - } - if (*cp == '\0') - return (1); - } + cp = hfield(*to, mp); + if (cp != NULL && strcasestr(cp, str) != NULL) + return (1); } return (0); } @@ -749,7 +730,7 @@ matchfield(str, mesg) int mesg; { struct message *mp; - char *cp, *cp2, *backup; + char *cp, *cp2; str++; if (*str == '\0') @@ -770,22 +751,14 @@ matchfield(str, mesg) cp2 = hfield(*str != '\0' ? str : "subject", mp); cp[-1] = ':'; str = cp; - } else { - cp = str; - cp2 = hfield("subject", mp); - } - if (cp2 == NULL) + cp = cp2; + } else + cp = hfield("subject", mp); + + if (cp == NULL) return (0); - backup = cp2; - while (*cp2 != '\0') { - if (*cp == '\0') - return (1); - if (toupper((unsigned char)*cp++) != toupper((unsigned char)*cp2++)) { - cp2 = ++backup; - cp = str; - } - } - return (*cp == 0); + + return (strcasestr(cp, str) != NULL); } /* |