aboutsummaryrefslogtreecommitdiffstats
path: root/src/writer.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-10-28 14:15:28 +0100
committerDavid Robillard <d@drobilla.net>2023-12-02 18:49:08 -0500
commitc8594c69b612005c7507ad00f7274ca7791197d7 (patch)
tree74a33b550deb1a953a6a9d53872c626878194206 /src/writer.c
parente750f4b6734d086e433e3c9c05b2252f43f4be8f (diff)
downloadserd-c8594c69b612005c7507ad00f7274ca7791197d7.tar.gz
serd-c8594c69b612005c7507ad00f7274ca7791197d7.tar.bz2
serd-c8594c69b612005c7507ad00f7274ca7791197d7.zip
Cache commonly used nodes in the world
Diffstat (limited to 'src/writer.c')
-rw-r--r--src/writer.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/src/writer.c b/src/writer.c
index 7afeb1c4..88c544d4 100644
--- a/src/writer.c
+++ b/src/writer.c
@@ -4,7 +4,6 @@
#include "block_dumper.h"
#include "env.h"
#include "memory.h"
-#include "namespaces.h"
#include "node.h"
#include "sink.h"
#include "string_utils.h"
@@ -758,14 +757,12 @@ write_literal(SerdWriter* const writer,
const char* const type_uri = datatype ? serd_node_string(datatype) : NULL;
if (supports_abbrev(writer) && type_uri) {
- if (!strncmp(type_uri, NS_XSD, sizeof(NS_XSD) - 1) &&
- (!strcmp(type_uri + sizeof(NS_XSD) - 1, "boolean") ||
- !strcmp(type_uri + sizeof(NS_XSD) - 1, "integer"))) {
+ if (serd_node_equals(datatype, writer->world->xsd_boolean) ||
+ serd_node_equals(datatype, writer->world->xsd_integer)) {
return esink(node_str, node->length, writer);
}
- if (!strncmp(type_uri, NS_XSD, sizeof(NS_XSD) - 1) &&
- !strcmp(type_uri + sizeof(NS_XSD) - 1, "decimal") &&
+ if (serd_node_equals(datatype, writer->world->xsd_decimal) &&
strchr(node_str, '.') && node_str[node->length - 1] != '.') {
/* xsd:decimal literals without trailing digits, e.g. "5.", can
not be written bare in Turtle. We could add a 0 which is
@@ -842,11 +839,12 @@ write_uri_node(SerdWriter* const writer,
const bool has_scheme = serd_uri_string_has_scheme(string.data);
if (supports_abbrev(writer)) {
- if (field == SERD_PREDICATE && !strcmp(string.data, NS_RDF "type")) {
+ if (field == SERD_PREDICATE &&
+ serd_node_equals(node, writer->world->rdf_type)) {
return esink("a", 1, writer);
}
- if (!strcmp(string.data, NS_RDF "nil")) {
+ if (serd_node_equals(node, writer->world->rdf_nil)) {
return esink("()", 2, writer);
}
@@ -972,12 +970,12 @@ write_list_next(SerdWriter* const writer,
{
SerdStatus st = SERD_SUCCESS;
- if (!strcmp(serd_node_string(object), NS_RDF "nil")) {
+ if (serd_node_equals(object, writer->world->rdf_nil)) {
TRY(st, write_sep(writer, writer->context.flags, SEP_LIST_END));
return SERD_FAILURE;
}
- if (!strcmp(serd_node_string(predicate), NS_RDF "first")) {
+ if (serd_node_equals(predicate, writer->world->rdf_first)) {
TRY(st, write_node(writer, object, SERD_OBJECT, flags));
} else {
TRY(st, write_sep(writer, writer->context.flags, SEP_LIST_SEP));
@@ -1084,8 +1082,8 @@ write_list_statement(SerdWriter* const writer,
{
SerdStatus st = SERD_SUCCESS;
- if (!strcmp(serd_node_string(predicate), NS_RDF "first") &&
- !strcmp(serd_node_string(object), NS_RDF "nil")) {
+ if (serd_node_equals(predicate, writer->world->rdf_first) &&
+ serd_node_equals(object, writer->world->rdf_nil)) {
return esink("()", 2, writer);
}