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>2019-04-13 19:15:32 +0200
commita339e2422fcffe41e515aff7eee3f501ca70f311 (patch)
tree28d87d4f2d8d09dc95554bb99398a6eb412e88dc /src/n3.c
parentd540aa4d29944f7716afe8c587f5145b551d8a50 (diff)
downloadserd-a339e2422fcffe41e515aff7eee3f501ca70f311.tar.gz
serd-a339e2422fcffe41e515aff7eee3f501ca70f311.tar.bz2
serd-a339e2422fcffe41e515aff7eee3f501ca70f311.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 a95a85b7..712c3cc7 100644
--- a/src/n3.c
+++ b/src/n3.c
@@ -1044,10 +1044,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;
}
@@ -1255,6 +1255,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);
}
@@ -1289,12 +1290,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) {