diff options
-rw-r--r-- | serd/serd.h | 7 | ||||
-rw-r--r-- | src/reader.c | 3 | ||||
-rw-r--r-- | src/sink.c | 3 | ||||
-rw-r--r-- | src/statement.c | 6 | ||||
-rw-r--r-- | src/statement.h | 3 |
5 files changed, 19 insertions, 3 deletions
diff --git a/serd/serd.h b/serd/serd.h index 4fa5a70d..d379ccee 100644 --- a/serd/serd.h +++ b/serd/serd.h @@ -1269,6 +1269,13 @@ const SerdNode* serd_statement_get_graph(const SerdStatement* statement); /** + Return the source location where `statement` originated, or NULL. +*/ +SERD_API +const SerdCursor* +serd_statement_get_cursor(const SerdStatement* statement); + +/** @} @name Cursor @{ diff --git a/src/reader.c b/src/reader.c index b34f5a0f..9da58e79 100644 --- a/src/reader.c +++ b/src/reader.c @@ -123,7 +123,8 @@ emit_statement(SerdReader* reader, ReadContext ctx, SerdNode* o) serd_node_zero_pad(o); const SerdStatement statement = { - { ctx.subject, ctx.predicate, o, graph } + { ctx.subject, ctx.predicate, o, graph }, + &reader->source.cur }; const SerdStatus st = reader->sink->statement( @@ -48,7 +48,8 @@ serd_sink_write_nodes(const SerdSink* sink, const SerdNode* object, const SerdNode* graph) { - const SerdStatement statement = { { subject, predicate, object, graph } }; + const SerdStatement statement = { { subject, predicate, object, graph }, + NULL }; return sink->statement(sink->handle, flags, &statement); } diff --git a/src/statement.c b/src/statement.c index 5e2802eb..24440a38 100644 --- a/src/statement.c +++ b/src/statement.c @@ -45,3 +45,9 @@ serd_statement_get_graph(const SerdStatement* statement) { return statement->nodes[SERD_GRAPH]; } + +const SerdCursor* +serd_statement_get_cursor(const SerdStatement* statement) +{ + return statement->cursor; +} diff --git a/src/statement.h b/src/statement.h index 7b5d752d..7c8384e9 100644 --- a/src/statement.h +++ b/src/statement.h @@ -27,7 +27,8 @@ typedef const SerdNode* SerdQuad[4]; struct SerdStatementImpl { - SerdQuad nodes; + SerdQuad nodes; + SerdCursor* cursor; }; #endif // SERD_STATEMENT_H |