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 0a05c395..9b34dcbb 100644 --- a/serd/serd.h +++ b/serd/serd.h @@ -1307,6 +1307,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 8bc8edd7..c294a6db 100644 --- a/src/reader.c +++ b/src/reader.c @@ -128,7 +128,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(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 |