aboutsummaryrefslogtreecommitdiffstats
path: root/src/node.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-06-15 09:26:17 -0400
committerDavid Robillard <d@drobilla.net>2022-01-13 23:03:27 -0500
commit6df8ef0e9b360f8d1a37723d0492bacc4a49f957 (patch)
tree90a5faa1c5cacebff10cd9b19245816c2e60ff92 /src/node.c
parent7a171498eca31ddedb0de1f372c982eca00d3d50 (diff)
downloadserd-6df8ef0e9b360f8d1a37723d0492bacc4a49f957.tar.gz
serd-6df8ef0e9b360f8d1a37723d0492bacc4a49f957.tar.bz2
serd-6df8ef0e9b360f8d1a37723d0492bacc4a49f957.zip
Bring read/write interface closer to C standard
Diffstat (limited to 'src/node.c')
-rw-r--r--src/node.c20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/node.c b/src/node.c
index 8f981856..8485c144 100644
--- a/src/node.c
+++ b/src/node.c
@@ -48,7 +48,6 @@ static const SerdNodeFlags meta_mask = (SERD_HAS_DATATYPE | SERD_HAS_LANGUAGE);
static SerdNode*
serd_new_from_uri(SerdURIView uri, SerdURIView base);
-SERD_PURE_FUNC
static size_t
serd_uri_string_length(const SerdURIView* const uri)
{
@@ -69,12 +68,15 @@ serd_uri_string_length(const SerdURIView* const uri)
}
static size_t
-string_sink(const void* const buf, const size_t len, void* const stream)
+string_sink(const void* const buf,
+ const size_t size,
+ const size_t nmemb,
+ void* const stream)
{
char** ptr = (char**)stream;
- memcpy(*ptr, buf, len);
- *ptr += len;
- return len;
+ memcpy(*ptr, buf, size * nmemb);
+ *ptr += size * nmemb;
+ return nmemb;
}
static size_t
@@ -390,16 +392,16 @@ serd_new_file_uri(const SerdStringView path, const SerdStringView hostname)
SerdBuffer buffer = {uri, uri_len};
for (size_t i = 0; i < path.len; ++i) {
if (is_windows && path.buf[i] == '\\') {
- serd_buffer_sink("/", 1, &buffer);
+ serd_buffer_sink("/", 1, 1, &buffer);
} else if (path.buf[i] == '%') {
- serd_buffer_sink("%%", 2, &buffer);
+ serd_buffer_sink("%%", 1, 2, &buffer);
} else if (is_uri_path_char(path.buf[i])) {
- serd_buffer_sink(path.buf + i, 1, &buffer);
+ serd_buffer_sink(path.buf + i, 1, 1, &buffer);
} else {
char escape_str[10] = {'%', 0, 0, 0, 0, 0, 0, 0, 0, 0};
snprintf(
escape_str + 1, sizeof(escape_str) - 1, "%X", (unsigned)path.buf[i]);
- serd_buffer_sink(escape_str, 3, &buffer);
+ serd_buffer_sink(escape_str, 1, 3, &buffer);
}
}
serd_buffer_sink_finish(&buffer);