aboutsummaryrefslogtreecommitdiffstats
path: root/src/env.c
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2018-09-30 17:31:10 +0200
committerDavid Robillard <d@drobilla.net>2019-04-13 19:15:32 +0200
commitbc46da00532dd8896c1bddb3b1f279811b25d4a1 (patch)
tree246777739a66afbb3d40537e0aa3a6529fec5a79 /src/env.c
parent5de7dc6ab43b15d01937364218862dc174343b31 (diff)
downloadserd-bc46da00532dd8896c1bddb3b1f279811b25d4a1.tar.gz
serd-bc46da00532dd8896c1bddb3b1f279811b25d4a1.tar.bz2
serd-bc46da00532dd8896c1bddb3b1f279811b25d4a1.zip
Add serd_env_copy() and serd_env_equals()
Diffstat (limited to 'src/env.c')
-rw-r--r--src/env.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/env.c b/src/env.c
index 6095ee30..fb1f183c 100644
--- a/src/env.c
+++ b/src/env.c
@@ -48,6 +48,22 @@ serd_env_new(const SerdNode* base_uri)
return env;
}
+SerdEnv*
+serd_env_copy(const SerdEnv* env)
+{
+ SerdEnv* copy = (SerdEnv*)calloc(1, sizeof(struct SerdEnvImpl));
+
+ copy->n_prefixes = env->n_prefixes;
+ copy->prefixes = (SerdPrefix*)malloc(copy->n_prefixes * sizeof(SerdPrefix));
+ for (size_t i = 0; i < copy->n_prefixes; ++i) {
+ copy->prefixes[i].name = serd_node_copy(env->prefixes[i].name);
+ copy->prefixes[i].uri = serd_node_copy(env->prefixes[i].uri);
+ }
+
+ serd_env_set_base_uri(copy, serd_env_get_base_uri(env));
+ return copy;
+}
+
void
serd_env_free(SerdEnv* env)
{
@@ -60,6 +76,26 @@ serd_env_free(SerdEnv* env)
free(env);
}
+bool
+serd_env_equals(const SerdEnv* a, const SerdEnv* b)
+{
+ if (!a || !b) {
+ return !a == !b;
+ } else if (a->n_prefixes != b->n_prefixes ||
+ !serd_node_equals(a->base_uri_node, b->base_uri_node)) {
+ return false;
+ }
+
+ for (size_t i = 0; i < a->n_prefixes; ++i) {
+ if (!serd_node_equals(a->prefixes[i].name, b->prefixes[i].name) ||
+ !serd_node_equals(a->prefixes[i].uri, b->prefixes[i].uri)) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
const SerdURI*
serd_env_get_parsed_base_uri(const SerdEnv* env)
{