diff options
author | David Robillard <d@drobilla.net> | 2020-08-12 20:54:05 +0200 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2020-10-27 13:13:59 +0100 |
commit | 7f1d50b40814db24573b9eb425566ce1d44d2e85 (patch) | |
tree | 56c87c5b0ed1b84027957888605e497d4521f0a0 /src | |
parent | aafc82f0bee3b222d395ef959aa4a6917f2ef0b2 (diff) | |
download | serd-7f1d50b40814db24573b9eb425566ce1d44d2e85.tar.gz serd-7f1d50b40814db24573b9eb425566ce1d44d2e85.tar.bz2 serd-7f1d50b40814db24573b9eb425566ce1d44d2e85.zip |
Make serd_env_expand() always return a node if it is not relative
The old interface was potentially faster, because it avoided unnecessary
copies, but was annoying to use and problematic because nodes that don't need
expansion were indistinguishable from nodes that failed to expand (like those
that use undefined namespace prefixes).
In the grand scheme of things, the potential performance improvement isn't
worth it, and unexpected unexpanded nodes causes deep nightmarish problems, so
just make serd_env_expand() copy the input if it doesn't need expansion to make
the API simpler and safer.
Diffstat (limited to 'src')
-rw-r--r-- | src/env.c | 30 |
1 files changed, 20 insertions, 10 deletions
@@ -295,23 +295,33 @@ expand_literal(const SerdEnv* env, const SerdNode* node) assert(serd_node_type(node) == SERD_LITERAL); const SerdNode* const datatype = serd_node_datatype(node); - if (datatype && serd_node_type(datatype) == SERD_CURIE) { + if (!datatype) { + return serd_node_copy(node); + } + + if (serd_node_type(datatype) == SERD_CURIE) { SerdStringView prefix; SerdStringView suffix; - if (!serd_env_expand_in_place(env, datatype, &prefix, &suffix)) { - return serd_new_typed_literal_expanded(serd_node_string(node), - serd_node_length(node), - serd_node_flags(node), - SERD_URI, - prefix, - suffix); + if (serd_env_expand_in_place(env, datatype, &prefix, &suffix)) { + return NULL; } - } else if (datatype && serd_node_type(datatype) == SERD_URI) { + + return serd_new_typed_literal_expanded(serd_node_string(node), + serd_node_length(node), + serd_node_flags(node), + SERD_URI, + prefix, + suffix); + + } else if (serd_node_type(datatype) == SERD_URI) { SerdURI datatype_uri; serd_uri_parse(serd_node_string(datatype), &datatype_uri); SerdURI abs_datatype_uri; serd_uri_resolve(&datatype_uri, &env->base_uri, &abs_datatype_uri); + if (abs_datatype_uri.scheme.len == 0) { + return NULL; + } return serd_new_typed_literal_uri(serd_node_string(node), serd_node_length(node), @@ -361,7 +371,7 @@ serd_env_expand(const SerdEnv* env, const SerdNode* node) case SERD_CURIE: return expand_curie(env, node); case SERD_BLANK: - return NULL; + return serd_node_copy(node); } } |