aboutsummaryrefslogtreecommitdiffstats
path: root/src/writer.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2023-04-05 18:28:27 -0400
committerDavid Robillard <d@drobilla.net>2023-12-02 18:49:07 -0500
commitee946a0de13a22ff83c288aa64ef3f4fd381da75 (patch)
treeab205c8c977203963eae308e6ec998f29e97a1e9 /src/writer.c
parentd62c7dc45af3256c6cd70d12a11e91b5b872c7db (diff)
downloadserd-ee946a0de13a22ff83c288aa64ef3f4fd381da75.tar.gz
serd-ee946a0de13a22ff83c288aa64ef3f4fd381da75.tar.bz2
serd-ee946a0de13a22ff83c288aa64ef3f4fd381da75.zip
Simplify statement flags
Diffstat (limited to 'src/writer.c')
-rw-r--r--src/writer.c41
1 files changed, 24 insertions, 17 deletions
diff --git a/src/writer.c b/src/writer.c
index ca17bbd9..23b2c0bd 100644
--- a/src/writer.c
+++ b/src/writer.c
@@ -847,13 +847,13 @@ write_blank(SerdWriter* const writer,
const char* const node_str = serd_node_string(node);
if (supports_abbrev(writer)) {
- if ((field == SERD_SUBJECT && (flags & SERD_ANON_S_BEGIN)) ||
- (field == SERD_OBJECT && (flags & SERD_ANON_O_BEGIN))) {
+ if ((field == SERD_SUBJECT && (flags & SERD_ANON_S)) ||
+ (field == SERD_OBJECT && (flags & SERD_ANON_O))) {
return write_sep(writer, SEP_ANON_BEGIN);
}
- if ((field == SERD_SUBJECT && (flags & SERD_LIST_S_BEGIN)) ||
- (field == SERD_OBJECT && (flags & SERD_LIST_O_BEGIN))) {
+ if ((field == SERD_SUBJECT && (flags & SERD_LIST_S)) ||
+ (field == SERD_OBJECT && (flags & SERD_LIST_O))) {
return write_sep(writer, SEP_LIST_BEGIN);
}
@@ -954,11 +954,11 @@ terminate_context(SerdWriter* writer)
{
SerdStatus st = SERD_SUCCESS;
- if (writer->context.subject && writer->context.subject->type) {
+ if (ctx(writer, SERD_SUBJECT)) {
TRY(st, write_sep(writer, SEP_END_S));
}
- if (writer->context.graph && writer->context.graph->type) {
+ if (ctx(writer, SERD_GRAPH)) {
TRY(st, write_sep(writer, SEP_GRAPH_END));
}
@@ -970,13 +970,20 @@ serd_writer_write_statement(SerdWriter* const writer,
const SerdStatementFlags flags,
const SerdStatement* const statement)
{
+ assert(!((flags & SERD_ANON_S) && (flags & SERD_LIST_S)));
+ assert(!((flags & SERD_EMPTY_S) && (flags & SERD_LIST_S)));
+ assert(!((flags & SERD_ANON_O) && (flags & SERD_LIST_O)));
+ assert(!((flags & SERD_EMPTY_O) && (flags & SERD_LIST_O)));
+
SerdStatus st = SERD_SUCCESS;
const SerdNode* const subject = serd_statement_subject(statement);
const SerdNode* const predicate = serd_statement_predicate(statement);
const SerdNode* const object = serd_statement_object(statement);
const SerdNode* const graph = serd_statement_graph(statement);
- if (!is_resource(subject) || !is_resource(predicate) || !object) {
+ if (!is_resource(subject) || !is_resource(predicate) || !object ||
+ ((flags & SERD_ANON_S) && (flags & SERD_LIST_S)) ||
+ ((flags & SERD_ANON_O) && (flags & SERD_LIST_O))) {
return SERD_BAD_ARG;
}
@@ -1008,7 +1015,7 @@ serd_writer_write_statement(SerdWriter* const writer,
}
}
- if ((flags & SERD_LIST_CONT)) {
+ if (writer->context.type == CTX_LIST) {
// Continue a list
if (!strcmp(serd_node_string(predicate), NS_RDF "first") &&
!strcmp(serd_node_string(object), NS_RDF "nil")) {
@@ -1026,8 +1033,8 @@ serd_writer_write_statement(SerdWriter* const writer,
// Elide S P (write O)
const Sep last = writer->last_sep;
- const bool anon_o = flags & SERD_ANON_O_BEGIN;
- const bool list_o = flags & SERD_LIST_O_BEGIN;
+ const bool anon_o = flags & SERD_ANON_O;
+ const bool list_o = flags & SERD_LIST_O;
const bool open_o = anon_o || list_o;
const bool after_end = (last == SEP_ANON_END) || (last == SEP_LIST_END);
@@ -1039,7 +1046,7 @@ serd_writer_write_statement(SerdWriter* const writer,
} else {
// Elide S (write P and O)
- if (writer->context.comma_indented) {
+ if (writer->context.comma_indented && !(flags & SERD_ANON_S)) {
--writer->indent;
writer->context.comma_indented = false;
}
@@ -1063,7 +1070,7 @@ serd_writer_write_statement(SerdWriter* const writer,
}
TRY(st, write_node(writer, subject, SERD_SUBJECT, flags));
- if ((flags & (SERD_ANON_S_BEGIN | SERD_LIST_S_BEGIN))) {
+ if ((flags & (SERD_ANON_S | SERD_LIST_S))) {
TRY(st, write_sep(writer, SEP_ANON_S_P));
} else {
TRY(st, write_sep(writer, SEP_S_P));
@@ -1076,16 +1083,16 @@ serd_writer_write_statement(SerdWriter* const writer,
reset_context(writer, 0U);
serd_node_set(&writer->context.subject, subject);
- if (!(flags & SERD_LIST_S_BEGIN)) {
+ if (!(flags & SERD_LIST_S)) {
TRY(st, write_pred(writer, flags, predicate));
}
TRY(st, write_node(writer, object, SERD_OBJECT, flags));
}
- if (flags & (SERD_ANON_S_BEGIN | SERD_LIST_S_BEGIN)) {
+ if (flags & (SERD_ANON_S | SERD_LIST_S)) {
// Push context for anonymous or list subject
- const bool is_list = (flags & SERD_LIST_S_BEGIN);
+ const bool is_list = (flags & SERD_LIST_S);
TRY(st,
push_context(writer,
is_list ? CTX_LIST : CTX_BLANK,
@@ -1094,11 +1101,11 @@ serd_writer_write_statement(SerdWriter* const writer,
is_list ? NULL : predicate));
}
- if (flags & (SERD_ANON_O_BEGIN | SERD_LIST_O_BEGIN)) {
+ if (flags & (SERD_ANON_O | SERD_LIST_O)) {
// Push context for anonymous or list object if necessary
TRY(st,
push_context(writer,
- (flags & SERD_LIST_O_BEGIN) ? CTX_LIST : CTX_BLANK,
+ (flags & SERD_LIST_O) ? CTX_LIST : CTX_BLANK,
graph,
object,
NULL));