aboutsummaryrefslogtreecommitdiffstats
path: root/src/string.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2016-03-15 23:37:09 -0400
committerDavid Robillard <d@drobilla.net>2018-11-25 09:21:03 +0100
commitd70d76deeb5735f97bb90792d5200ee812fb50b0 (patch)
tree45704de9956c4e96db0dfd686d94876b720cb96b /src/string.c
parentf046eb982627f344fc0eeff6be82028318862e67 (diff)
downloadserd-d70d76deeb5735f97bb90792d5200ee812fb50b0.tar.gz
serd-d70d76deeb5735f97bb90792d5200ee812fb50b0.tar.bz2
serd-d70d76deeb5735f97bb90792d5200ee812fb50b0.zip
Remove useless character counting
Diffstat (limited to 'src/string.c')
-rw-r--r--src/string.c45
1 files changed, 15 insertions, 30 deletions
diff --git a/src/string.c b/src/string.c
index cde82134..024f8bd0 100644
--- a/src/string.c
+++ b/src/string.c
@@ -56,46 +56,31 @@ serd_update_flags(const uint8_t c, SerdNodeFlags* const flags)
size_t
serd_substrlen(const uint8_t* const str,
const size_t len,
- size_t* const n_bytes,
SerdNodeFlags* const flags)
{
- size_t n_chars = 0;
- size_t i = 0;
- SerdNodeFlags f = 0;
- for (; i < len && str[i]; ++i) {
- if ((str[i] & 0xC0) != 0x80) { // Start of new character
- ++n_chars;
- serd_update_flags(str[i], &f);
- }
- }
- if (n_bytes) {
- *n_bytes = i;
- }
if (flags) {
- *flags = f;
+ size_t i = 0;
+ *flags = 0;
+ for (; i < len && str[i]; ++i) {
+ serd_update_flags(str[i], flags);
+ }
+ return i;
}
- return n_chars;
+ return strlen((const char*)str);
}
size_t
-serd_strlen(const uint8_t* str, size_t* n_bytes, SerdNodeFlags* flags)
+serd_strlen(const uint8_t* str, SerdNodeFlags* flags)
{
- size_t n_chars = 0;
- size_t i = 0;
- SerdNodeFlags f = 0;
- for (; str[i]; ++i) {
- if ((str[i] & 0xC0) != 0x80) { // Start of new character
- ++n_chars;
- serd_update_flags(str[i], &f);
- }
- }
- if (n_bytes) {
- *n_bytes = i;
- }
if (flags) {
- *flags = f;
+ size_t i = 0;
+ *flags = 0;
+ for (; str[i]; ++i) {
+ serd_update_flags(str[i], flags);
+ }
+ return i;
}
- return n_chars;
+ return strlen((const char*)str);
}
static inline double