aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2019-03-10 16:21:56 +0100
committerDavid Robillard <d@drobilla.net>2021-03-08 23:23:05 -0500
commit6f6dc590561d1d73a15eb9501e0d22e28f26508b (patch)
tree0a54a3fe73f1121ff70dcb2bfb609ca5893618ee
parent5b319b320879618d316031a60ef9836fcf70deb2 (diff)
downloadserd-6f6dc590561d1d73a15eb9501e0d22e28f26508b.tar.gz
serd-6f6dc590561d1d73a15eb9501e0d22e28f26508b.tar.bz2
serd-6f6dc590561d1d73a15eb9501e0d22e28f26508b.zip
Simplify internal writer context API
-rw-r--r--src/writer.c62
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