diff options
author | Mattias Andrée <maandree@operamail.com> | 2015-11-20 07:07:55 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2015-11-20 07:07:55 +0100 |
commit | 2ccd77c0c9bde78f3811bbc9b256197515532c88 (patch) | |
tree | a811844b72fa00c61c6dd438d5bbd5d7fc115cf3 /src/string | |
parent | typo (diff) | |
download | slibc-2ccd77c0c9bde78f3811bbc9b256197515532c88.tar.gz slibc-2ccd77c0c9bde78f3811bbc9b256197515532c88.tar.bz2 slibc-2ccd77c0c9bde78f3811bbc9b256197515532c88.tar.xz |
add optimised variants of *casecmp
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to '')
-rw-r--r-- | src/string/new.c | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/src/string/new.c b/src/string/new.c index 50b47cf..28d2b22 100644 --- a/src/string/new.c +++ b/src/string/new.c @@ -729,3 +729,79 @@ char* (strcnends)(const char* string, const char* desired, int stop, size_t maxl return (memcmp)(string + (n - m), desired, m) ? NULL : (string + n); } +int strlowercmp(const char* a, const char* b) /* slibc */ +{ + return strnlowercmp(a, b, SIZE_MAX); +} + +int struppercmp(const char* a, const char* b) /* slibc: completeness */ +{ + return strnuppercmp(a, b, SIZE_MAX); +} + +int strnlowercmp(const char* a, const char* b, size_t length) /* slibc: completeness */ +{ + int c1, c2; + for (; length--; a++, b++) + if (*a != *b) + { + c1 = isalpha(*a) ? tolower(*a) : (int)*a; + c2 = *b; + if ((c1 -= c2)) + return c1; + } + else if (!*a && !*b) return 0; + else if (!*a) return -1; + else if (!*b) return +1; + return 0; +} + +int strnuppercmp(const char* a, const char* b, size_t length) /* slibc: completeness */ +{ + int c1, c2; + for (; length--; a++, b++) + if (*a != *b) + { + c1 = isalpha(*a) ? toupper(*a) : (int)*a; + c2 = *b; + if ((c1 -= c2)) + return c1; + } + else if (!*a && !*b) return 0; + else if (!*a) return -1; + else if (!*b) return +1; + return 0; +} + +int memlowercmp(const void* a, const void* b, size_t size) /* slibc: completeness */ +{ + const signed char* s1 = a; + const signed char* s2 = b; + int c1, c2; + for (; size--; s1++, s2++) + if (*s1 != *s2) + { + c1 = isalpha(*s1) ? tolower(*s1) : (int)*s1; + c2 = *s2; + if ((c1 -= c2)) + return c1; + } + return 0; +} + +int memuppercmp(const void* a, const void* b, size_t size) /* slibc: completeness */ +{ + const signed char* s1 = a; + const signed char* s2 = b; + int c1, c2; + for (; size--; s1++, s2++) + if (*s1 != *s2) + { + c1 = isalpha(*s1) ? toupper(*s1) : (int)*s1; + c2 = *s2; + if ((c1 -= c2)) + return c1; + } + return 0; +} + |