diff options
author | David Robillard <d@drobilla.net> | 2011-04-29 23:02:24 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-04-29 23:02:24 +0000 |
commit | 2aebf86c27288254da4765116686101a88840cbd (patch) | |
tree | 78beebd64ac17141a804471896f8389285395f6e | |
parent | f89cead131a61c0b58bc4e706df339db3f1b9965 (diff) | |
download | lilv-2aebf86c27288254da4765116686101a88840cbd.tar.gz lilv-2aebf86c27288254da4765116686101a88840cbd.tar.bz2 lilv-2aebf86c27288254da4765116686101a88840cbd.zip |
Faster implementations of lilv_plugin_get_one and lilv_plugin_get_unique.
git-svn-id: http://svn.drobilla.net/lad/trunk/lilv@3239 a436a847-0d15-0410-975c-d299462d15a1
-rw-r--r-- | src/plugin.c | 40 | ||||
-rw-r--r-- | src/world.c | 2 |
2 files changed, 19 insertions, 23 deletions
diff --git a/src/plugin.c b/src/plugin.c index 5841bd2..32c40da 100644 --- a/src/plugin.c +++ b/src/plugin.c @@ -81,35 +81,31 @@ lilv_plugin_free(LilvPlugin* p) free(p); } -LilvNode* -lilv_plugin_get_unique(const LilvPlugin* p, - const SordNode* subject, - const SordNode* predicate) +static LilvNode* +lilv_plugin_get_one(const LilvPlugin* p, + const SordNode* subject, + const SordNode* predicate) { - LilvNodes* values = lilv_world_query_values(p->world, - subject, predicate, NULL); - if (!values || lilv_nodes_size(values) != 1) { - LILV_ERRORF("Port does not have exactly one `%s' property\n", - sord_node_get_string(predicate)); - return NULL; + LilvNode* ret = NULL; + SordIter* stream = lilv_world_query(p->world, subject, predicate, NULL); + if (!lilv_matches_end(stream)) { + ret = lilv_node_new_from_node(p->world, lilv_match_object(stream)); } - LilvNode* ret = lilv_node_duplicate(lilv_nodes_get_first(values)); - lilv_nodes_free(values); + lilv_match_end(stream); return ret; } -static LilvNode* -lilv_plugin_get_one(const LilvPlugin* p, - const SordNode* subject, - const SordNode* predicate) +LilvNode* +lilv_plugin_get_unique(const LilvPlugin* p, + const SordNode* subject, + const SordNode* predicate) { - LilvNodes* values = lilv_world_query_values(p->world, - subject, predicate, NULL); - if (!values) { - return NULL; + LilvNode* ret = lilv_plugin_get_one(p, subject, predicate); + if (!ret) { + LILV_ERRORF("Multiple values found for (%s %s ...) property\n", + sord_node_get_string(subject), + sord_node_get_string(predicate)); } - LilvNode* ret = lilv_node_duplicate(lilv_nodes_get_first(values)); - lilv_nodes_free(values); return ret; } diff --git a/src/world.c b/src/world.c index 5d093d0..336970f 100644 --- a/src/world.c +++ b/src/world.c @@ -744,7 +744,7 @@ lilv_world_load_all(LilvWorld* world) LILV_FOREACH(plugins, p, world->plugins) { const LilvPlugin* plugin = lilv_collection_get(world->plugins, p); - const LilvNode* plugin_uri = lilv_plugin_get_uri(plugin); + const LilvNode* plugin_uri = lilv_plugin_get_uri(plugin); // ?new dc:replaces plugin SordIter* replacement = lilv_world_find_statements( |