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>2019-12-18 19:25:23 -0500
commit92cafa8938c48ecdf9b9338cc62bde750211497b (patch)
tree3c8611b39986ea8b7ddeab1f31942d1798d6e7a0 /src/string.c
parent7594722a6145db5caf422638c875673b558ff4db (diff)
downloadserd-92cafa8938c48ecdf9b9338cc62bde750211497b.tar.gz
serd-92cafa8938c48ecdf9b9338cc62bde750211497b.tar.bz2
serd-92cafa8938c48ecdf9b9338cc62bde750211497b.zip
Remove useless character counting
Diffstat (limited to 'src/string.c')
-rw-r--r--src/string.c46
1 files changed, 16 insertions, 30 deletions
diff --git a/src/string.c b/src/string.c
index 0869bc23..075af52d 100644
--- a/src/string.c
+++ b/src/string.c
@@ -56,46 +56,32 @@ 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;
+ assert(flags);
+
+ size_t i = 0;
+ *flags = 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;
+ serd_update_flags(str[i], flags);
}
- if (flags) {
- *flags = f;
- }
- return n_chars;
+
+ return i;
}
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