diff options
author | David Robillard <d@drobilla.net> | 2019-03-10 16:21:56 +0100 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2021-03-08 23:23:05 -0500 |
commit | 6f6dc590561d1d73a15eb9501e0d22e28f26508b (patch) | |
tree | 0a54a3fe73f1121ff70dcb2bfb609ca5893618ee /src | |
parent | 5b319b320879618d316031a60ef9836fcf70deb2 (diff) | |
download | serd-6f6dc590561d1d73a15eb9501e0d22e28f26508b.tar.gz serd-6f6dc590561d1d73a15eb9501e0d22e28f26508b.tar.bz2 serd-6f6dc590561d1d73a15eb9501e0d22e28f26508b.zip |
Simplify internal writer context API
Diffstat (limited to 'src')
-rw-r--r-- | src/writer.c | 62 |
1 files changed, 31 insertions, 31 deletions
diff --git a/src/writer.c b/src/writer.c index 0930a187..17f1dc22 100644 --- a/src/writer.c +++ b/src/writer.c @@ -157,8 +157,12 @@ free_context(SerdWriter* writer) return SERD_SUCCESS; } -static inline SerdStatus -push_context(SerdWriter* writer, const WriteContext new_context) +static SerdStatus +push_context(SerdWriter* const writer, + const ContextType type, + const SerdNode* const g, + const SerdNode* const s, + const SerdNode* const p) { WriteContext* top = (WriteContext*)serd_stack_push(&writer->anon_stack, sizeof(WriteContext)); @@ -167,7 +171,11 @@ push_context(SerdWriter* writer, const WriteContext new_context) return SERD_ERR_OVERFLOW; } - *top = writer->context; + *top = writer->context; + + const WriteContext new_context = { + type, serd_node_copy(g), serd_node_copy(s), serd_node_copy(p), false}; + writer->context = new_context; return SERD_SUCCESS; } @@ -969,42 +977,34 @@ serd_writer_write_statement(SerdWriter* writer, write_node(writer, object, SERD_OBJECT, flags); } - // Push context for anonymous or list subject if necessary - if (flags & (SERD_ANON_S | SERD_LIST_S)) { - const bool is_list = (flags & SERD_LIST_S); - - const WriteContext ctx = {is_list ? CTX_LIST : CTX_BLANK, - serd_node_copy(graph), - serd_node_copy(subject), - is_list ? NULL : serd_node_copy(predicate), - false}; - if ((st = push_context(writer, ctx))) { - return st; + // Push context for list or anonymous subject if necessary + if (!st) { + if (flags & SERD_ANON_S) { + st = push_context(writer, CTX_BLANK, graph, subject, predicate); + } else if (flags & SERD_LIST_S) { + st = push_context(writer, CTX_LIST, graph, subject, NULL); } } - // Push context for anonymous or list object if necessary - if (flags & (SERD_ANON_O | SERD_LIST_O)) { - const bool is_list = (flags & SERD_LIST_O); - - const WriteContext ctx = {is_list ? CTX_LIST : CTX_BLANK, - serd_node_copy(graph), - serd_node_copy(object), - NULL, - false}; - if ((st = push_context(writer, ctx))) { - return st; + // Push context for list or anonymous object if necessary + if (!st) { + if (flags & SERD_ANON_O) { + st = push_context(writer, CTX_BLANK, graph, object, NULL); + } else if (flags & SERD_LIST_O) { + st = push_context(writer, CTX_LIST, graph, object, NULL); } } - if (!(flags & (SERD_ANON_S | SERD_LIST_S | SERD_ANON_O | SERD_LIST_O))) { - // Update current context to this statement - serd_node_set(&writer->context.graph, graph); - serd_node_set(&writer->context.subject, subject); - serd_node_set(&writer->context.predicate, predicate); + // Update current context to this statement if this isn't a new context + if (!st) { + if (!(flags & (SERD_ANON_S | SERD_LIST_S | SERD_ANON_O | SERD_LIST_O))) { + serd_node_set(&writer->context.graph, graph); + serd_node_set(&writer->context.subject, subject); + serd_node_set(&writer->context.predicate, predicate); + } } - return SERD_SUCCESS; + return st; } static SerdStatus |