/** * slibc — Yet another C library * Copyright © 2015 Mattias Andrée (maandree@member.fsf.org) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include size_t strclen(const char* string, int stop) /* slibc: completeness */ { return (size_t)(strchrnul(string, stop) - string); } size_t strcnlen(const char* string, int stop, size_t maxlen) /* slibc: completeness */ { const char* end = strnchr(string, stop, maxlen); return end ? (size_t)(end - string) : maxlen; } size_t strstrlen(const char* string, const char* stop) /* slibc: completeness */ { const char* end = strstr(string, stop); return end ? (size_t)(end - string) : strlen(string); } size_t strstrnlen(const char* string, const char* stop, size_t maxlen) /* slibc: completeness */ { const char* end = strnstr(string, stop, maxlen); return end ? (size_t)(end - string) : maxlen; } char* (strnchr)(const char* string, int c, size_t maxlen) /* slibc: completeness */ { for (;;) if (*string == c) return string; else if (!*string++ || !maxlen--) return NULL; } char* (strnchrnul)(const char* string, int c, size_t maxlen) /* slibc+gnu: completeness */ { for (;; string++) if (*string == c) return string; else if (!*string || !maxlen--) return string; } char* (memcchr)(const char* segment, int c, int stop, size_t size) /* slibc: completeness */ { char* s = segment; for (;;) if (*s == c) return s; else if ((*s++ == stop) || !size--) return NULL; } char* (strcchr)(const char* string, int c, int stop) /* slibc: completeness */ { for (;;) if (*string == c) return string; else if (!*string || (*string++ == stop)) return NULL; } char* (strcnchr)(const char* string, int c, int stop, size_t maxlen) /* slibc: completeness */ { for (;;) if (*string == c) return string; else if (!*string || (*string++ == stop) || !maxlen--) return NULL; } char* (strcchrnul)(const char* string, int c, int stop) /* slibc+gnu: completeness */ { for (;; string++) if (*string == c) return string; else if (!*string || (*string == stop)) return string; } char* (strcnchrnul)(const char* string, int c, int stop, size_t maxlen) /* slibc+gnu: completeness */ { for (;; string++) if (*string == c) return string; else if (!*string || (*string == stop) || !maxlen--) return string; } char* (strnrchr)(const char* string, int c, size_t maxlen) /* slibc: completeness */ { char* r = NULL; while (maxlen--) if (*string == c) r = string; else if (!*string++) return c ? r : (string - 1); } void* (memcrchr)(const void* segment, int c, int stop, size_t size) /* slibc: completeness */ { char* r = NULL; for (;; size--) if (*segment == c) r = segment; else if ((*segment == stop) || !size) return r; } char* (strcrchr)(const char* string, int c, int stop) /* slibc: completeness */ { char* r = NULL; for (;;) if (*string == c) r = string; else if (!*string++) return c ? r : (string - 1); else if (*string == stop) return r; } char* (strcnrchr)(const char* string, int c, int stop, size_t maxlen) /* slibc: completeness */ { char* r = NULL; while (maxlen--) if (*string == c) r = string; else if (!*string++) return c ? r : (string - 1); } void* (rawmemrchr)(const void* segment, int c, size_t size) /* slibc+gnu: completeness */ { char* s = segment; for (;;) if (s[--size] == c) return s + size; } void* (rawmemcasemem)(const void* haystack, const void* needle, size_t needle_length) /* slibc */ { return (memcasemem)(haystack, SIZE_MAX, needle, needle_length); } void* (rawmemmem)(const void* haystack, const void* needle, size_t needle_length) /* slibc */ { return (memmem)(haystack, SIZE_MAX, needle, needle_length); } void* (memccasemem)(const void* haystack, size_t haystack_length, const void* needle, size_t needle_length, int stop) /* slibc: completeness */ { const void* p = memchr(haystack, stop, haystack_length); return (memcasemem)(haystack, p ? (size_t)(p - haystack) : haystack_length, needle, needle_length); } void* (memcmem)(const void* haystack, size_t haystack_length, const void* needle, size_t needle_length, int stop) /* slibc: completeness */ { const void* p = memchr(haystack, stop, haystack_length); return (memmem)(haystack, p ? (size_t)(p - haystack) : haystack_length, needle, needle_length); } char* (strccasestr)(const char* haystack, const char* needle, int stop) /* slibc: completeness */ { return (memcasemem)(haystack, strclen(haystack, stop), needle, strlen(needle)); } char* (strcstr)(const char* haystack, const char* needle, int stop) /* slibc: completeness */ { return (memmem)(haystack, strclen(haystack, stop), needle, strlen(needle)); } char* (strcncasestr)(const char* haystack, const char* needle, int stop, size_t maxlen) /* slibc: completeness */ { return (memcasemem)(haystack, strcnlen(haystack, stop, maxlen), needle, strlen(needle)); } char* (strcnstr)(const char* haystack, const char* needle, int stop, size_t maxlen) /* slibc: completeness */ { return (memmem)(haystack, strcnlen(haystack, stop, maxlen), needle, strlen(needle)); } char* (strpcbrk)(const char* string, const char* skipset) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *skipset++)) set[(size_t)c] = 1; while ((c = *s++)) if (set[(size_t)c]) break; return c ? (s - 1) : NULL; } char* (strpbrknul)(const char* string, const char* stopset) /* slibc */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *stopset++)) set[(size_t)c] = 1; while ((c = *s++)) if (!set[(size_t)c]) break; return s - 1; } char* (strpcbrknul)(const char* string, const char* skipset) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *skipset++)) set[(size_t)c] = 1; while ((c = *s++)) if (set[(size_t)c]) break; return s - 1; } char* (strnpbrk)(const char* string, const char* stopset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *stopset++)) set[(size_t)c] = 1; while (maxlen-- && ((c = *s++))) if (!set[(size_t)c]) break; return c ? (s - 1) : NULL; } char* (strnpcbrk)(const char* string, const char* skipset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *skipset++)) set[(size_t)c] = 1; while (maxlen-- && ((c = *s++))) if (set[(size_t)c]) break; return c ? (s - 1) : NULL; } char* (strnpbrknul)(const char* string, const char* stopset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *stopset++)) set[(size_t)c] = 1; while (maxlen-- && ((c = *s++))) if (!set[(size_t)c]) break; return s - 1; } char* (strnpcbrknul)(const char* string, const char* skipset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256 * sizeof(char)); while ((c = *skipset++)) set[(size_t)c] = 1; while (maxlen-- && ((c = *s++))) if (set[(size_t)c]) break; return s - 1; } size_t strnspn(const char* string, const char* skipset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256); while ((c = *skipset++)) set[(size_t)c] = 1; for (; maxlen && ((c = *s++)); maxlen--) if (set[(size_t)c]) break; return (size_t)(s - !!maxlen - string); } size_t strncspn(const char* string, const char* stopset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; memset(set, 0, 256); while ((c = *stopset++)) set[(size_t)c] = 1; for (; maxlen && ((c = *s++)); maxlen--) if (!set[(size_t)c]) break; return (size_t)(s - !!maxlen - string); } char* strnsep(char** restrict string, const char* restrict delimiters, size_t* restrict maxlen) /* slibc: completeness */ { char* r = *string; char* next; if (r == NULL) return NULL; next = strnpbrk(r, delimiters, *maxlen); if (next != NULL) *next++ = 0, *maxlen -= (size_t)(next - r); *string = next; return r; } char* strntok(char* restrict string, const char* restrict delimiters, char** restrict state, size_t* restrict maxlen) /* slibc: completeness */ { char* r; if (string == NULL) *state = string; for (;;) { r = strnsep(state, delimiters, maxlen); if (r == NULL) return NULL; if (*r) return r; } } char* (strprbrk)(const char* string, const char* stopset) /* slibc: completeness */ { char set[256]; char c; const char* s = string; const char* r = NULL; memset(set, 0, 256); while ((c = *stopset++)) set[(size_t)c] = 1; while ((c = *s++)) if (!set[(size_t)c]) r = s - 1; return r; } char* (strprcbrk)(const char* string, const char* skipset) /* slibc: completeness */ { char set[256]; char c; const char* s = string; const char* r = NULL; memset(set, 0, 256 * sizeof(char)); while ((c = *skipset++)) set[(size_t)c] = 1; while ((c = *s++)) if (set[(size_t)c]) r = s - 1; return r; } char* (strnprbrk)(const char* string, const char* stopset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; const char* r = NULL; memset(set, 0, 256 * sizeof(char)); while ((c = *stopset++)) set[(size_t)c] = 1; while (maxlen-- && ((c = *s++))) if (!set[(size_t)c]) r = s - 1; return r; } char* (strnprcbrk)(const char* string, const char* skipset, size_t maxlen) /* slibc: completeness */ { char set[256]; char c; const char* s = string; const char* r = NULL; memset(set, 0, 256 * sizeof(char)); while ((c = *skipset++)) set[(size_t)c] = 1; while (maxlen-- && ((c = *s++))) if (set[(size_t)c]) r = s - 1; return r; } char* memmemmove(char* whither, const char* whence, const char* restrict str, size_t strsize, size_t size) /* slibc: completeness */ { char* stop = (memmem)(whence, size, str, strsize); void* r = NULL; if (stop != NULL) size = (size_t)(stop - (const char*)whence), r = whither + size; memmove(whither, whence, size); return r; } char* memmemcpy(void* whither, const void* whence, const char* restrict str, size_t strsize, size_t size) /* slibc: completeness */ { char* stop = (memmem)(whence, size, str, strsize); void* r = NULL; if (stop != NULL) size = (size_t)(stop - (const char*)whence), r = whither + size; memcpy(whither, whence, size); return r; }