#include "str.h" #include "stralloc.h" /** @file str.c @author djb @source qmail @brief string handling functions */ unsigned int str_copy(register char *s, register const char *t) { register int len; len = 0; for (;;) { // clang-format off if (!(*s = *t)) { return len; } ++s; ++t; ++len; if (!(*s = *t)) { return len; } ++s; ++t; ++len; if (!(*s = *t)) { return len; } ++s; ++t; ++len; if (!(*s = *t)) { return len; } ++s; ++t; ++len; // clang-format on } } unsigned int str_copyb(register char *s, register const char *t, unsigned int max) { register int len; len = 0; while (max-- > 0) { // clang-format off if (!(*s = *t)) { return len; } ++s; ++t; ++len; if (!(*s = *t)) { return len; } ++s; ++t; ++len; if (!(*s = *t)) { return len; } ++s; ++t; ++len; if (!(*s = *t)) { return len; } ++s; ++t; ++len; // clang-format on } return len; } int str_diff(register const char *s, register const char *t) { register char x; for (;;) { // clang-format off x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; // clang-format on } return ((int)(unsigned int)(unsigned char)x) - ((int)(unsigned int)(unsigned char)*t); } int str_diffn(register const char *s, register const char *t, unsigned int len) { register char x; for (;;) { // clang-format off if (!len--) { return 0; } x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; if (!len--) { return 0; } x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; if (!len--) { return 0; } x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; if (!len--) { return 0; } x = *s; if (x != *t) { break; } if (!x) { break; } ++s; ++t; // clang-format on } return ((int)(unsigned int)(unsigned char)x) - ((int)(unsigned int)(unsigned char)*t); } unsigned int str_len(register const char *s) { register const char *t; t = s; for (;;) { // clang-format off if (!*t) { return t - s; } ++t; if (!*t) { return t - s; } ++t; if (!*t) { return t - s; } ++t; if (!*t) { return t - s; } ++t; // clang-format on } } unsigned int str_chr(register const char *s, int c) { register char ch; register const char *t; ch = c; t = s; for (;;) { // clang-format off if (!*t) { break; } if (*t == ch) { break; } ++t; if (!*t) { break; } if (*t == ch) { break; } ++t; if (!*t) { break; } if (*t == ch) { break; } ++t; if (!*t) { break; } if (*t == ch) { break; } ++t; // clang-format on } return t - s; } unsigned int str_rchr(register const char *s, int c) { register char ch; register const char *t; register const char *u; ch = c; t = s; u = 0; for (;;) { // clang-format off if (!*t) { break; } if (*t == ch) { u = t; } ++t; if (!*t) { break; } if (*t == ch) { u = t; } ++t; if (!*t) { break; } if (*t == ch) { u = t; } ++t; if (!*t) { break; } if (*t == ch) { u = t; } ++t; // clang-format on } if (!u) u = t; return u - s; } int str_start(register const char *s, register const char *t) { register char x; for (;;) { // clang-format off x = *t++; if (!x) return 1; if (x != *s++) return 0; x = *t++; if (!x) return 1; if (x != *s++) return 0; x = *t++; if (!x) return 1; if (x != *s++) return 0; x = *t++; if (!x) return 1; if (x != *s++) return 0; // clang-format on } } char *str_append(char *dest, const char *s) { static stralloc sa = {0}; stralloc_copys(&sa, dest); stralloc_catb(&sa, s, sizeof(s)); return sa.s; }