aboutsummaryrefslogtreecommitdiffstats
path: root/src/n3.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-05-13 00:48:31 +0200
committerDavid Robillard <d@drobilla.net>2018-12-31 11:37:47 -0500
commit299e386243004582a323507a5e17482b28d31b69 (patch)
treed273f9a13b751be1b5a212bcbfe91107fe269db5 /src/n3.c
parent3a62732bd03d1d0ba9daef1667afafa213828bf4 (diff)
downloadserd-299e386243004582a323507a5e17482b28d31b69.tar.gz
serd-299e386243004582a323507a5e17482b28d31b69.tar.bz2
serd-299e386243004582a323507a5e17482b28d31b69.zip
Zero node padding before passing to reader sinks
Diffstat (limited to 'src/n3.c')
-rw-r--r--src/n3.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/src/n3.c b/src/n3.c
index ed7a39f3..4a0b031f 100644
--- a/src/n3.c
+++ b/src/n3.c
@@ -1052,10 +1052,10 @@ read_object(SerdReader* reader, ReadContext* ctx, bool emit, bool* ate_dot)
o->flags = flags;
}
- if (ret && emit && simple) {
+ if (ret && emit && simple && o) {
ret = emit_statement(reader, *ctx, o);
} else if (ret && !emit) {
- ctx->object = o;
+ ctx->object = o;
return true;
}
@@ -1263,6 +1263,7 @@ read_base(SerdReader* reader, bool sparql, bool token)
if (!uri) {
return false;
} else if (reader->sink->base) {
+ serd_node_zero_pad(uri);
reader->sink->base(reader->sink->handle, uri);
}
@@ -1297,12 +1298,14 @@ read_prefixID(SerdReader* reader, bool sparql, bool token)
}
read_ws_star(reader);
- const SerdNode* uri = read_IRIREF(reader);
+ SerdNode* uri = read_IRIREF(reader);
if (!uri) {
return false;
}
if (reader->sink->prefix) {
+ serd_node_zero_pad(name);
+ serd_node_zero_pad(uri);
ret = !reader->sink->prefix(reader->sink->handle, name, uri);
}
if (!sparql) {