aboutsummaryrefslogtreecommitdiffstats
path: root/src/uri.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2021-10-27 14:15:31 -0400
committerDavid Robillard <d@drobilla.net>2022-01-28 21:57:24 -0500
commit30487c277ac5d4be5786733ca7b98adb4c810ae9 (patch)
treef1b00a7725d74a594fcd91de2aea924485356528 /src/uri.c
parent56cceb103dc633d6af957472945e792187a5dd4e (diff)
downloadserd-30487c277ac5d4be5786733ca7b98adb4c810ae9.tar.gz
serd-30487c277ac5d4be5786733ca7b98adb4c810ae9.tar.bz2
serd-30487c277ac5d4be5786733ca7b98adb4c810ae9.zip
Add custom allocator support
Diffstat (limited to 'src/uri.c')
-rw-r--r--src/uri.c35
1 files changed, 27 insertions, 8 deletions
diff --git a/src/uri.c b/src/uri.c
index bbd53ca3..fad1d188 100644
--- a/src/uri.c
+++ b/src/uri.c
@@ -14,6 +14,7 @@
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
+#include "memory.h"
#include "string_utils.h"
#include "uri_utils.h"
@@ -26,7 +27,9 @@
#include <string.h>
char*
-serd_parse_file_uri(const char* const uri, char** const hostname)
+serd_parse_file_uri(SerdAllocator* const allocator,
+ const char* const uri,
+ char** const hostname)
{
assert(uri);
@@ -46,7 +49,10 @@ serd_parse_file_uri(const char* const uri, char** const hostname)
if (hostname) {
const size_t len = (size_t)(path - auth);
- *hostname = (char*)calloc(len + 1, 1);
+ if (!(*hostname = (char*)serd_acalloc(allocator, len + 1, 1))) {
+ return NULL;
+ }
+
memcpy(*hostname, auth, len);
}
}
@@ -56,26 +62,39 @@ serd_parse_file_uri(const char* const uri, char** const hostname)
++path;
}
- SerdBuffer buffer = {NULL, 0};
+ SerdBuffer buffer = {allocator, NULL, 0};
for (const char* s = path; *s; ++s) {
if (*s == '%') {
if (*(s + 1) == '%') {
- serd_buffer_write("%", 1, 1, &buffer);
+ if (serd_buffer_write("%", 1, 1, &buffer) != 1) {
+ serd_afree(allocator, buffer.buf);
+ return NULL;
+ }
+
++s;
} else if (is_hexdig(*(s + 1)) && is_hexdig(*(s + 2))) {
const char code[3] = {*(s + 1), *(s + 2), 0};
const char c = (char)strtoul(code, NULL, 16);
- serd_buffer_write(&c, 1, 1, &buffer);
+ if (serd_buffer_write(&c, 1, 1, &buffer) != 1) {
+ serd_afree(allocator, buffer.buf);
+ return NULL;
+ }
+
s += 2;
} else {
s += 2; // Junk escape, ignore
}
- } else {
- serd_buffer_write(s, 1, 1, &buffer);
+ } else if (serd_buffer_write(s, 1, 1, &buffer) != 1) {
+ serd_afree(allocator, buffer.buf);
+ return NULL;
}
}
- serd_buffer_close(&buffer);
+ if (serd_buffer_close(&buffer)) {
+ serd_afree(allocator, buffer.buf);
+ return NULL;
+ }
+
return (char*)buffer.buf;
}