diff options
-rw-r--r-- | src/env.c | 52 |
1 files changed, 35 insertions, 17 deletions
@@ -8,6 +8,7 @@ #include "serd/node.h" +#include <assert.h> #include <stdbool.h> #include <stdio.h> #include <stdlib.h> @@ -186,6 +187,7 @@ serd_env_qualify(const SerdEnv* const env, const SerdNode* const uri) const size_t prefix_len = serd_node_length(prefix); const size_t length = prefix_len + 1 + suffix.length; SerdNode* node = serd_node_malloc(length, 0, SERD_CURIE); + memcpy(serd_node_buffer(node), serd_node_string(prefix), prefix_len); serd_node_buffer(node)[prefix_len] = ':'; memcpy(serd_node_buffer(node) + 1 + prefix_len, suffix.data, suffix.length); @@ -220,8 +222,36 @@ serd_env_expand_in_place(const SerdEnv* const env, return SERD_BAD_CURIE; } +static SerdNode* +expand_uri(const SerdEnv* env, const SerdNode* node) +{ + assert(serd_node_type(node) == SERD_URI); + + return serd_new_resolved_uri(serd_node_string_view(node), env->base_uri); +} + +static SerdNode* +expand_curie(const SerdEnv* env, const SerdNode* node) +{ + assert(serd_node_type(node) == SERD_CURIE); + + SerdStringView prefix; + SerdStringView suffix; + if (serd_env_expand_in_place(env, node, &prefix, &suffix)) { + return NULL; + } + + const size_t len = prefix.length + suffix.length; + SerdNode* ret = serd_node_malloc(len, 0, SERD_URI); + char* buf = serd_node_buffer(ret); + + snprintf(buf, len + 1, "%s%s", prefix.data, suffix.data); + ret->length = len; + return ret; +} + SerdNode* -serd_env_expand(const SerdEnv* const env, const SerdNode* const node) +serd_env_expand(const SerdEnv* env, const SerdNode* node) { if (!env || !node) { return NULL; @@ -231,25 +261,13 @@ serd_env_expand(const SerdEnv* const env, const SerdNode* const node) case SERD_LITERAL: break; case SERD_URI: - return serd_new_resolved_uri(serd_node_string_view(node), env->base_uri); - case SERD_CURIE: { - SerdStringView prefix; - SerdStringView suffix; - if (serd_env_expand_in_place(env, node, &prefix, &suffix)) { - return NULL; - } - - const size_t len = prefix.length + suffix.length; - SerdNode* ret = serd_node_malloc(len, 0, SERD_URI); - char* buf = serd_node_buffer(ret); - - snprintf(buf, len + 1, "%s%s", prefix.data, suffix.data); - ret->length = len; - return ret; - } + return expand_uri(env, node); + case SERD_CURIE: + return expand_curie(env, node); case SERD_BLANK: break; } + return NULL; } |