summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/Makefile.am2
-rw-r--r--src/plugin.c17
-rw-r--r--src/private_types.h7
-rw-r--r--src/query.c6
-rw-r--r--src/world.c (renamed from src/model.c)98
5 files changed, 63 insertions, 67 deletions
diff --git a/src/Makefile.am b/src/Makefile.am
index eb25597..8009ff8 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -6,7 +6,7 @@ libslv2_la_LIBADD = @REDLAND_LIBS@
libslv2_la_SOURCES = \
private_types.h \
- model.c \
+ world.c \
plugin.c \
query.c \
port.c \
diff --git a/src/plugin.c b/src/plugin.c
index ab36caf..b3577f2 100644
--- a/src/plugin.c
+++ b/src/plugin.c
@@ -31,10 +31,10 @@
/* private */
SLV2Plugin
-slv2_plugin_new(SLV2Model model, librdf_uri* uri, const char* binary_uri)
+slv2_plugin_new(SLV2World world, librdf_uri* uri, const char* binary_uri)
{
struct _Plugin* plugin = malloc(sizeof(struct _Plugin));
- plugin->model = model;
+ plugin->world = world;
plugin->plugin_uri = librdf_new_uri_from_uri(uri);
plugin->binary_uri = strdup(binary_uri);
plugin->data_uris = raptor_new_sequence((void (*)(void*))&raptor_free_uri, NULL);
@@ -84,11 +84,9 @@ slv2_plugin_query(SLV2Plugin plugin,
SLV2Plugin
slv2_plugin_duplicate(SLV2Plugin p)
{
- fprintf(stderr, "FIXME: duplicate\n");
-
assert(p);
struct _Plugin* result = malloc(sizeof(struct _Plugin));
- result->model = p->model;
+ result->world = p->world;
result->plugin_uri = librdf_new_uri_from_uri(p->plugin_uri);
//result->bundle_url = strdup(p->bundle_url);
@@ -102,7 +100,6 @@ slv2_plugin_duplicate(SLV2Plugin p)
for (int i=0; i < raptor_sequence_size(p->ports); ++i)
raptor_sequence_push(result->ports, slv2_port_duplicate(raptor_sequence_get_at(p->ports, i)));
- result->ports = NULL;
result->storage = NULL;
result->rdf = NULL;
@@ -133,15 +130,15 @@ slv2_plugin_load(SLV2Plugin p)
if (!p->storage) {
assert(!p->rdf);
- p->storage = librdf_new_storage(p->model->world, "hashes", NULL,
+ p->storage = librdf_new_storage(p->world->world, "hashes", NULL,
"hash-type='memory'");
- p->rdf = librdf_new_model(p->model->world, p->storage, NULL);
+ p->rdf = librdf_new_model(p->world->world, p->storage, NULL);
}
// Parse all the plugin's data files into RDF model
for (int i=0; i < raptor_sequence_size(p->data_uris); ++i) {
librdf_uri* data_uri = raptor_sequence_get_at(p->data_uris, i);
- librdf_parser_parse_into_model(p->model->parser, data_uri, NULL, p->rdf);
+ librdf_parser_parse_into_model(p->world->parser, data_uri, NULL, p->rdf);
}
// Load ports
@@ -153,7 +150,7 @@ slv2_plugin_load(SLV2Plugin p)
" :index ?index .\n"
"}";
- librdf_query* q = librdf_new_query(p->model->world, "sparql",
+ librdf_query* q = librdf_new_query(p->world->world, "sparql",
NULL, query, p->plugin_uri);
librdf_query_results* results = librdf_query_execute(q, p->rdf);
diff --git a/src/private_types.h b/src/private_types.h
index 12f74cb..8f2f89d 100644
--- a/src/private_types.h
+++ b/src/private_types.h
@@ -48,8 +48,7 @@ void slv2_port_free(SLV2Port port);
* paths of relevant files, the actual data therein isn't loaded into memory.
*/
struct _Plugin {
- int deletable;
- struct _Model* model;
+ struct _World* world;
librdf_uri* plugin_uri;
// char* bundle_url; // Bundle directory plugin was loaded from
char* binary_uri; // lv2:binary
@@ -59,7 +58,7 @@ struct _Plugin {
librdf_model* rdf;
};
-SLV2Plugin slv2_plugin_new(SLV2Model model, librdf_uri* uri, const char* binary_uri);
+SLV2Plugin slv2_plugin_new(SLV2World world, librdf_uri* uri, const char* binary_uri);
void slv2_plugin_load(SLV2Plugin p);
@@ -77,7 +76,7 @@ struct _InstanceImpl {
/** Model of LV2 (RDF) data loaded from bundles.
*/
-struct _Model {
+struct _World {
librdf_world* world;
librdf_storage* storage;
librdf_model* model;
diff --git a/src/query.c b/src/query.c
index 7127a8d..968834c 100644
--- a/src/query.c
+++ b/src/query.c
@@ -124,7 +124,7 @@ slv2_plugin_query(SLV2Plugin plugin,
//printf("******** Query \n%s********\n", query_str);
- librdf_query *rq = librdf_new_query(plugin->model->world, "sparql", NULL,
+ librdf_query *rq = librdf_new_query(plugin->world->world, "sparql", NULL,
(const unsigned char*)query_str, base_uri);
if (!rq) {
@@ -200,7 +200,7 @@ slv2_query_count_results(SLV2Plugin p,
assert(p);
assert(query_str);
- librdf_query *rq = librdf_new_query(p->model->world, "sparql", NULL,
+ librdf_query *rq = librdf_new_query(p->world->world, "sparql", NULL,
(unsigned char*)query_str, NULL);
//printf("Query: \n%s\n\n", query_str);
@@ -209,7 +209,7 @@ slv2_query_count_results(SLV2Plugin p,
//librdf_query_add_data_graph(rq, slv2_ontology_uri,
// NULL, RASQAL_DATA_GRAPH_BACKGROUND);
- librdf_query_results* results = librdf_query_execute(rq, p->model->model);
+ librdf_query_results* results = librdf_query_execute(rq, p->world->model);
assert(results);
size_t count = slv2_query_count_bindings(results);
diff --git a/src/model.c b/src/world.c
index 16a1962..afb71ad 100644
--- a/src/model.c
+++ b/src/world.c
@@ -22,65 +22,65 @@
#include <dirent.h>
#include <string.h>
#include <librdf.h>
-#include <slv2/model.h>
+#include <slv2/world.h>
#include <slv2/slv2.h>
#include <slv2/util.h>
#include "config.h"
#include "private_types.h"
-SLV2Model
-slv2_model_new()
+SLV2World
+slv2_world_new()
{
- struct _Model* model = (struct _Model*)malloc(sizeof(struct _Model));
+ struct _World* world = (struct _World*)malloc(sizeof(struct _World));
- model->world = librdf_new_world();
- librdf_world_open(model->world);
+ world->world = librdf_new_world();
+ librdf_world_open(world->world);
- model->storage = librdf_new_storage(model->world, "hashes", NULL,
+ world->storage = librdf_new_storage(world->world, "hashes", NULL,
"hash-type='memory'");
- model->model = librdf_new_model(model->world, model->storage, NULL);
+ world->model = librdf_new_model(world->world, world->storage, NULL);
- model->parser = librdf_new_parser(model->world, "turtle", NULL, NULL);
+ world->parser = librdf_new_parser(world->world, "turtle", NULL, NULL);
- model->plugins = slv2_plugins_new();
+ world->plugins = slv2_plugins_new();
/*slv2_ontology_uri = raptor_new_uri((const unsigned char*)
"file://" LV2_TTL_PATH);*/
- return model;
+ return world;
}
void
-slv2_model_free(SLV2Model model)
+slv2_world_free(SLV2World world)
{
/*raptor_free_uri(slv2_ontology_uri);
slv2_ontology_uri = NULL;*/
- slv2_plugins_free(model->plugins);
- model->plugins = NULL;
+ slv2_plugins_free(world->plugins);
+ world->plugins = NULL;
- librdf_free_parser(model->parser);
- model->parser = NULL;
+ librdf_free_parser(world->parser);
+ world->parser = NULL;
- librdf_free_model(model->model);
- model->model = NULL;
+ librdf_free_model(world->model);
+ world->model = NULL;
- librdf_free_storage(model->storage);
- model->storage = NULL;
+ librdf_free_storage(world->storage);
+ world->storage = NULL;
- librdf_free_world(model->world);
- model->world = NULL;
+ librdf_free_world(world->world);
+ world->world = NULL;
- free(model);
+ free(world);
}
/* private */
void
-slv2_model_load_directory(SLV2Model model, const char* dir)
+slv2_world_load_directory(SLV2World world, const char* dir)
{
DIR* pdir = opendir(dir);
if (!pdir)
@@ -92,7 +92,7 @@ slv2_model_load_directory(SLV2Model model, const char* dir)
continue;
char* bundle_uri_str = slv2_strjoin("file://", dir, "/", pfile->d_name, "/", NULL);
- librdf_uri* bundle_uri = librdf_new_uri(model->world, (unsigned char*)bundle_uri_str);
+ librdf_uri* bundle_uri = librdf_new_uri(world->world, (unsigned char*)bundle_uri_str);
DIR* bundle_dir = opendir(bundle_uri_str + 7);
@@ -102,7 +102,7 @@ slv2_model_load_directory(SLV2Model model, const char* dir)
librdf_uri* manifest_uri = librdf_new_uri_relative_to_base(
bundle_uri, (const unsigned char*)"manifest.ttl");
- librdf_parser_parse_into_model(model->parser, manifest_uri, NULL, model->model);
+ librdf_parser_parse_into_model(world->parser, manifest_uri, NULL, world->model);
librdf_free_uri(manifest_uri);
}
@@ -116,7 +116,7 @@ slv2_model_load_directory(SLV2Model model, const char* dir)
void
-slv2_model_load_path(SLV2Model model,
+slv2_world_load_path(SLV2World world,
const char* lv2_path)
{
char* path = slv2_strjoin(lv2_path, ":", NULL);
@@ -128,7 +128,7 @@ slv2_model_load_path(SLV2Model model,
char* delim = strchr(path, ':');
*delim = '\0';
- slv2_model_load_directory(model, dir);
+ slv2_world_load_directory(world, dir);
*delim = 'X';
dir = delim + 1;
@@ -151,13 +151,13 @@ slv2_plugin_compare_by_uri(const void* a, const void* b)
*/
void
-slv2_model_load_all(SLV2Model model)
+slv2_world_load_all(SLV2World world)
{
char* lv2_path = getenv("LV2_PATH");
// Read all manifest files
if (lv2_path) {
- slv2_model_load_path(model, lv2_path);
+ slv2_world_load_path(world, lv2_path);
} else {
const char* const home = getenv("HOME");
const char* const suffix = "/.lv2:/usr/local/lib/lv2:usr/lib/lv2";
@@ -165,7 +165,7 @@ slv2_model_load_all(SLV2Model model)
//fprintf(stderr, "$LV2_PATH is unset. Using default path %s\n", lv2_path);
- slv2_model_load_path(model, lv2_path);
+ slv2_world_load_path(world, lv2_path);
free(lv2_path);
}
@@ -180,10 +180,10 @@ slv2_model_load_all(SLV2Model model)
"OPTIONAL { ?plugin :binary ?binary } }\n"
"ORDER BY ?plugin\n";
- librdf_query* q = librdf_new_query(model->world, "sparql",
+ librdf_query* q = librdf_new_query(world->world, "sparql",
NULL, query_string, NULL);
- librdf_query_results* results = librdf_query_execute(q, model->model);
+ librdf_query_results* results = librdf_query_execute(q, world->model);
while (!librdf_query_results_finished(results)) {
@@ -194,20 +194,20 @@ slv2_model_load_all(SLV2Model model)
librdf_node* binary_node = librdf_query_results_get_binding_value(results, 2);
librdf_uri* binary_uri = librdf_node_get_uri(binary_node);
- SLV2Plugin plugin = slv2_plugins_get_by_uri(model->plugins,
+ SLV2Plugin plugin = slv2_plugins_get_by_uri(world->plugins,
(const char*)librdf_uri_as_string(plugin_uri));
// Create a new SLV2Plugin
if (!plugin)
- plugin = slv2_plugin_new(model, plugin_uri,
+ plugin = slv2_plugin_new(world, plugin_uri,
(const char*)librdf_uri_as_string(binary_uri));
- plugin->model = model;
+ plugin->world = world;
// FIXME: check for duplicates
raptor_sequence_push(plugin->data_uris, librdf_new_uri_from_uri(data_uri));
- raptor_sequence_push(model->plugins, plugin);
+ raptor_sequence_push(world->plugins, plugin);
librdf_free_node(plugin_node);
librdf_free_node(data_node);
@@ -216,7 +216,7 @@ slv2_model_load_all(SLV2Model model)
}
// ORDER BY should (and appears to actually) guarantee this
- //raptor_sequence_sort(model->plugins, slv2_plugin_compare_by_uri);
+ //raptor_sequence_sort(world->plugins, slv2_plugin_compare_by_uri);
if (results)
librdf_free_query_results(results);
@@ -227,7 +227,7 @@ slv2_model_load_all(SLV2Model model)
#if 0
void
-slv2_model_serialize(const char* filename)
+slv2_world_serialize(const char* filename)
{
librdf_uri* lv2_uri = librdf_new_uri(slv2_rdf_world,
(unsigned char*)"http://lv2plug.in/ontology#");
@@ -240,14 +240,14 @@ slv2_model_serialize(const char* filename)
"turtle", NULL, NULL);
librdf_serializer_set_namespace(serializer, lv2_uri, "");
librdf_serializer_set_namespace(serializer, rdfs_uri, "rdfs");
- librdf_serializer_serialize_model_to_file(serializer, filename, NULL, slv2_model);
+ librdf_serializer_serialize_world_to_file(serializer, filename, NULL, slv2_model);
librdf_free_serializer(serializer);
}
#endif
SLV2Plugins
-slv2_model_get_all_plugins(SLV2Model model)
+slv2_world_get_all_plugins(SLV2World world)
{
// FIXME: Slow..
@@ -255,8 +255,8 @@ slv2_model_get_all_plugins(SLV2Model model)
// our locally stored plugins
raptor_sequence* result = raptor_new_sequence(NULL, NULL);
- for (int i=0; i < raptor_sequence_size(model->plugins); ++i)
- raptor_sequence_push(result, raptor_sequence_get_at(model->plugins, i));
+ for (int i=0; i < raptor_sequence_size(world->plugins); ++i)
+ raptor_sequence_push(result, raptor_sequence_get_at(world->plugins, i));
// sorted?
@@ -265,9 +265,9 @@ slv2_model_get_all_plugins(SLV2Model model)
SLV2Plugins
-slv2_model_get_plugins_by_filter(SLV2Model model, bool (*include)(SLV2Plugin))
+slv2_world_get_plugins_by_filter(SLV2World world, bool (*include)(SLV2Plugin))
{
- SLV2Plugins all = slv2_model_get_all_plugins(model);
+ SLV2Plugins all = slv2_world_get_all_plugins(world);
SLV2Plugins result = slv2_plugins_new();
for (int i=0; i < raptor_sequence_size(all); ++i) {
@@ -283,14 +283,14 @@ slv2_model_get_plugins_by_filter(SLV2Model model, bool (*include)(SLV2Plugin))
#if 0
SLV2Plugins
-slv2_model_get_plugins_by_query(SLV2Model model, const char* query)
+slv2_world_get_plugins_by_query(SLV2World world, const char* query)
{
SLV2Plugins list = slv2_plugins_new();
- librdf_query* rq = librdf_new_query(model->world, "sparql",
+ librdf_query* rq = librdf_new_query(world->world, "sparql",
NULL, (const unsigned char*)query, NULL);
- librdf_query_results* results = librdf_query_execute(rq, model->model);
+ librdf_query_results* results = librdf_query_execute(rq, world->model);
while (!librdf_query_results_finished(results)) {
librdf_node* plugin_node = librdf_query_results_get_binding_value(results, 0);
@@ -301,7 +301,7 @@ slv2_model_get_plugins_by_query(SLV2Model model, const char* query)
/* Create a new SLV2Plugin */
if (!plugin) {
- SLV2Plugin new_plugin = slv2_plugin_new(model, plugin_uri);
+ SLV2Plugin new_plugin = slv2_plugin_new(world, plugin_uri);
raptor_sequence_push(list, new_plugin);
}