[utils] adding functions for finding the next index of a full stop/period charater in a string

This commit is contained in:
Al
2017-10-27 04:07:28 -04:00
parent e38e57b8e8
commit 6d430f7e9b
2 changed files with 48 additions and 0 deletions

View File

@@ -668,6 +668,45 @@ inline bool string_contains_hyphen(char *str) {
return string_next_hyphen_index(str, strlen(str)) >= 0;
}
ssize_t string_next_codepoint_len(char *str, uint32_t codepoint, size_t len) {
uint8_t *ptr = (uint8_t *)str;
int32_t ch;
ssize_t idx = 0;
while (idx < len) {
ssize_t char_len = utf8proc_iterate(ptr, len, &ch);
if (char_len <= 0 || ch == 0) break;
if ((uint32_t)ch == codepoint) return idx;
ptr += char_len;
idx += char_len;
}
return -1;
}
ssize_t string_next_codepoint(char *str, uint32_t codepoint) {
return string_next_codepoint_len(str, codepoint, strlen(str));
}
#define PERIOD_CODEPOINT 46
ssize_t string_next_period_len(char *str, size_t len) {
return string_next_codepoint_len(str, PERIOD_CODEPOINT, len);
}
ssize_t string_next_period(char *str) {
return string_next_codepoint(str, PERIOD_CODEPOINT);
}
inline bool string_contains_period_len(char *str, size_t len) {
return string_next_codepoint_len(str, PERIOD_CODEPOINT, len) >= 0;
}
inline bool string_contains_period(char *str) {
return string_next_codepoint(str, string_next_codepoint(str, PERIOD_CODEPOINT)) >= 0;
}
size_t string_right_spaces_len(char *str, size_t len) {
size_t spaces = 0;