diff options
author | David Robillard <d@drobilla.net> | 2018-05-13 00:48:31 +0200 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2019-04-13 19:15:32 +0200 |
commit | a339e2422fcffe41e515aff7eee3f501ca70f311 (patch) | |
tree | 28d87d4f2d8d09dc95554bb99398a6eb412e88dc /src/n3.c | |
parent | d540aa4d29944f7716afe8c587f5145b551d8a50 (diff) | |
download | serd-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.c | 9 |
1 files changed, 6 insertions, 3 deletions
@@ -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) { |