summaryrefslogtreecommitdiffstats
path: root/src/libs/serialisation
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2008-07-28 21:56:03 +0000
committerDavid Robillard <d@drobilla.net>2008-07-28 21:56:03 +0000
commita6fb6a0289ea47692d87f3e0200532a426f8e60d (patch)
tree0e497255eb8a263ff9cca87b2ed125b71144cacb /src/libs/serialisation
parent8e2ba26101828dcf310e0a43ace7aa68dafd3b16 (diff)
downloadingen-a6fb6a0289ea47692d87f3e0200532a426f8e60d.tar.gz
ingen-a6fb6a0289ea47692d87f3e0200532a426f8e60d.tar.bz2
ingen-a6fb6a0289ea47692d87f3e0200532a426f8e60d.zip
Simply global memory management crap by using shared_ptr in the World struct (it's not C anyway, might as well).
Properly support LV2 events from plugin UIs over OSC and directly (w/ monolithic UI/engine). Fix crashes on node destruction with monolithic UI/engine. Resolves ticket #177. git-svn-id: http://svn.drobilla.net/lad/ingen@1293 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/libs/serialisation')
-rw-r--r--src/libs/serialisation/Loader.cpp111
-rw-r--r--src/libs/serialisation/Loader.hpp15
2 files changed, 62 insertions, 64 deletions
diff --git a/src/libs/serialisation/Loader.cpp b/src/libs/serialisation/Loader.cpp
index 84b935d9..da2e6507 100644
--- a/src/libs/serialisation/Loader.cpp
+++ b/src/libs/serialisation/Loader.cpp
@@ -42,13 +42,12 @@ namespace Serialisation {
* @return whether or not load was successful.
*/
bool
-Loader::load(SharedPtr<EngineInterface> engine,
- Redland::World* rdf_world,
- const Glib::ustring& document_uri,
- boost::optional<Path> parent,
- string patch_name,
- Glib::ustring patch_uri,
- GraphObject::Variables data)
+Loader::load(Ingen::Shared::World* world,
+ const Glib::ustring& document_uri,
+ boost::optional<Raul::Path> parent,
+ std::string patch_name,
+ Glib::ustring patch_uri,
+ GraphObject::Variables data)
{
setlocale(LC_NUMERIC, "C");
@@ -56,7 +55,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
std::set<Path> created;
- Redland::Model model(*rdf_world, document_uri, document_uri);
+ Redland::Model model(*world->rdf_world, document_uri, document_uri);
if (patch_uri == "")
patch_uri = string("<") + document_uri + ">";
@@ -75,11 +74,11 @@ Loader::load(SharedPtr<EngineInterface> engine,
/* Get polyphony from file (mandatory if not specified in parameters) */
} else {
// FIXME: polyphony datatype?
- Redland::Query query(*rdf_world, Glib::ustring(
+ Redland::Query query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?poly WHERE {\n") +
patch_uri + " ingen:polyphony ?poly\n }");
- Redland::Query::Results results = query.run(*rdf_world, model);
+ Redland::Query::Results results = query.run(*world->rdf_world, model);
if (results.size() == 0) {
cerr << "[Loader] ERROR: No polyphony found!" << endl;
@@ -98,11 +97,11 @@ Loader::load(SharedPtr<EngineInterface> engine,
if (patch_name.substr(patch_name.length()-10) == ".ingen.ttl")
patch_name = patch_name.substr(0, patch_name.length()-10);
- Redland::Query query(*rdf_world, Glib::ustring(
+ Redland::Query query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?name WHERE {\n") +
patch_uri + " ingen:name ?name\n}");
- Redland::Query::Results results = query.run(*rdf_world, model);
+ Redland::Query::Results results = query.run(*world->rdf_world, model);
if (results.size() > 0)
patch_name = (*results.begin())["name"].to_string();
@@ -113,15 +112,15 @@ Loader::load(SharedPtr<EngineInterface> engine,
cout << " as " << patch_path << endl;
if (patch_path != "/")
- engine->create_patch(patch_path, patch_poly);
+ world->engine->create_patch(patch_path, patch_poly);
/* Set document metadata (so File->Save doesn't prompt)
* FIXME: This needs some thinking for multiple clients... */
- engine->set_variable(patch_path, "ingen:document", Atom(document_uri.c_str()));
+ world->engine->set_variable(patch_path, "ingen:document", Atom(document_uri.c_str()));
/* Load (plugin) nodes */
- Redland::Query query(*rdf_world, Glib::ustring(
+ Redland::Query query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?name ?plugin ?varkey ?varval ?poly WHERE {\n") +
patch_uri + " ingen:node ?node .\n"
"?node ingen:name ?name ;\n"
@@ -133,11 +132,11 @@ Loader::load(SharedPtr<EngineInterface> engine,
" }"
"}");
- Redland::Query::Results results = query.run(*rdf_world, model);
+ Redland::Query::Results results = query.run(*world->rdf_world, model);
map<const string, const Atom> variable;
- rdf_world->mutex().lock();
+ world->rdf_world->mutex().lock();
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
@@ -145,37 +144,37 @@ Loader::load(SharedPtr<EngineInterface> engine,
const Path node_path = patch_path.base() + node_name;
if (created.find(node_path) == created.end()) {
- const string node_plugin = rdf_world->qualify((*i)["plugin"].to_string());
+ const string node_plugin = world->rdf_world->qualify((*i)["plugin"].to_string());
bool node_polyphonic = false;
Redland::Node poly_node = (*i)["poly"];
if (poly_node.is_bool() && poly_node.to_bool() == true)
node_polyphonic = true;
- engine->create_node(node_path, node_plugin, node_polyphonic);
+ world->engine->create_node(node_path, node_plugin, node_polyphonic);
created.insert(node_path);
}
- const string key = rdf_world->prefixes().qualify((*i)["varkey"].to_string());
+ const string key = world->rdf_world->prefixes().qualify((*i)["varkey"].to_string());
Redland::Node val_node = (*i)["varval"];
if (key != "")
- engine->set_variable(node_path, key, AtomRDF::node_to_atom(val_node));
+ world->engine->set_variable(node_path, key, AtomRDF::node_to_atom(val_node));
}
- rdf_world->mutex().unlock();
+ world->rdf_world->mutex().unlock();
/* Load subpatches */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?patch ?name WHERE {\n") +
patch_uri + " ingen:node ?patch .\n"
"?patch a ingen:Patch ;\n"
" ingen:name ?name .\n"
"}");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
@@ -186,7 +185,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
if (created.find(subpatch_path) == created.end()) {
created.insert(subpatch_path);
- load(engine, rdf_world, document_uri, patch_path, name, patch);
+ load(world, document_uri, patch_path, name, patch);
}
}
@@ -195,7 +194,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
/* Set node port control values */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?nodename ?portname ?portval WHERE {\n") +
patch_uri + " ingen:node ?node .\n"
"?node ingen:name ?nodename ;\n"
@@ -205,7 +204,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
"FILTER ( datatype(?portval) = xsd:decimal )\n"
"}\n");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
@@ -216,13 +215,13 @@ Loader::load(SharedPtr<EngineInterface> engine,
const Path port_path = patch_path.base() + Path::nameify(node_name)
+"/"+ Path::nameify(port_name);
- engine->set_port_value(port_path, "ingen:control", sizeof(float), &val);
+ world->engine->set_port_value(port_path, "ingen:Float", sizeof(float), &val);
}
/* Load this patch's ports */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?port ?type ?name ?datatype ?varkey ?varval ?portval WHERE {\n") +
patch_uri + " ingen:port ?port .\n"
"?port a ?type ;\n"
@@ -237,32 +236,32 @@ Loader::load(SharedPtr<EngineInterface> engine,
" }"
"}");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
const string name = (*i)["name"].to_string();
- const string type = rdf_world->qualify((*i)["type"].to_string());
- const string datatype = rdf_world->qualify((*i)["datatype"].to_string());
+ const string type = world->rdf_world->qualify((*i)["type"].to_string());
+ const string datatype = world->rdf_world->qualify((*i)["datatype"].to_string());
const Path port_path = patch_path.base() + (string)name;
if (created.find(port_path) == created.end()) {
bool is_output = (type == "ingen:OutputPort"); // FIXME: check validity
- engine->create_port(port_path, datatype, is_output);
+ world->engine->create_port(port_path, datatype, is_output);
created.insert(port_path);
}
const Redland::Node val_node = (*i)["portval"];
if (val_node.is_float()) {
const float val = val_node.to_float();
- engine->set_port_value(patch_path.base() + name, "ingen:control", sizeof(float), &val);
+ world->engine->set_port_value(patch_path.base() + name, "ingen:Float", sizeof(float), &val);
}
- const string key = rdf_world->prefixes().qualify((*i)["varkey"].to_string());
+ const string key = world->rdf_world->prefixes().qualify((*i)["varkey"].to_string());
const Redland::Node var_val_node = (*i)["varval"];
if (key != "")
- engine->set_variable(patch_path.base() + name, key, AtomRDF::node_to_atom(var_val_node));
+ world->engine->set_variable(patch_path.base() + name, key, AtomRDF::node_to_atom(var_val_node));
}
created.clear();
@@ -270,7 +269,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
/* Node -> Node connections */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?srcnodename ?srcname ?dstnodename ?dstname WHERE {\n") +
patch_uri + "ingen:node ?srcnode ;\n"
" ingen:node ?dstnode .\n"
@@ -283,7 +282,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
" ingen:name ?dstname .\n"
"}\n");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
Path src_node = patch_path.base() + Path::nameify((*i)["srcnodename"].to_string());
@@ -293,13 +292,13 @@ Loader::load(SharedPtr<EngineInterface> engine,
//cerr << patch_path << " 1 CONNECTION: " << src_port << " -> " << dst_port << endl;
- engine->connect(src_port, dst_port);
+ world->engine->connect(src_port, dst_port);
}
/* This Patch -> Node connections */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?srcname ?dstnodename ?dstname WHERE {\n") +
patch_uri + " ingen:port ?src ;\n"
" ingen:node ?dstnode .\n"
@@ -310,7 +309,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
"?src ingen:name ?srcname .\n"
"}\n");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
Path src_port = patch_path.base() + Path::nameify((*i)["srcname"].to_string());
@@ -319,13 +318,13 @@ Loader::load(SharedPtr<EngineInterface> engine,
//cerr << patch_path << " 2 CONNECTION: " << src_port << " -> " << dst_port << endl;
- engine->connect(src_port, dst_port);
+ world->engine->connect(src_port, dst_port);
}
/* Node -> This Patch connections */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?srcnodename ?srcname ?dstname WHERE {\n") +
patch_uri + " ingen:port ?dst ;\n"
" ingen:node ?srcnode .\n"
@@ -336,7 +335,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
"?src ingen:name ?srcname .\n"
"}\n");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
Path dst_port = patch_path.base() + Path::nameify((*i)["dstname"].to_string());
@@ -345,13 +344,13 @@ Loader::load(SharedPtr<EngineInterface> engine,
//cerr << patch_path << " 3 CONNECTION: " << src_port << " -> " << dst_port << endl;
- engine->connect(src_port, dst_port);
+ world->engine->connect(src_port, dst_port);
}
/* This Patch -> This Patch connections */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?srcname ?dstname WHERE {\n") +
patch_uri + " ingen:port ?src ;\n"
" ingen:port ?dst .\n"
@@ -360,7 +359,7 @@ Loader::load(SharedPtr<EngineInterface> engine,
"?src ingen:name ?srcname .\n"
"}\n");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
Path src_port = patch_path.base() + Path::nameify((*i)["srcname"].to_string());
@@ -368,51 +367,51 @@ Loader::load(SharedPtr<EngineInterface> engine,
//cerr << patch_path << " 4 CONNECTION: " << src_port << " -> " << dst_port << endl;
- engine->connect(src_port, dst_port);
+ world->engine->connect(src_port, dst_port);
}
/* Load variables */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?varkey ?varval WHERE {\n") +
patch_uri + " ingen:variable ?variable .\n"
"?variable ingen:key ?varkey ;\n"
" ingen:value ?varval .\n"
"}");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
- const string key = rdf_world->prefixes().qualify(string((*i)["varkey"]));
+ const string key = world->rdf_world->prefixes().qualify(string((*i)["varkey"]));
Redland::Node val_node = (*i)["varval"];
if (key != "")
- engine->set_variable(patch_path, key, AtomRDF::node_to_atom(val_node));
+ world->engine->set_variable(patch_path, key, AtomRDF::node_to_atom(val_node));
}
// Set passed variables last to override any loaded values
for (GraphObject::Variables::const_iterator i = data.begin(); i != data.end(); ++i)
- engine->set_variable(patch_path, i->first, i->second);
+ world->engine->set_variable(patch_path, i->first, i->second);
/* Enable */
- query = Redland::Query(*rdf_world, Glib::ustring(
+ query = Redland::Query(*world->rdf_world, Glib::ustring(
"SELECT DISTINCT ?enabled WHERE {\n") +
patch_uri + " ingen:enabled ?enabled .\n"
"}");
- results = query.run(*rdf_world, model);
+ results = query.run(*world->rdf_world, model);
for (Redland::Query::Results::iterator i = results.begin(); i != results.end(); ++i) {
Redland::Node enabled_node = (*i)["enabled"];
if (enabled_node.is_bool() && enabled_node) {
- engine->enable_patch(patch_path);
+ world->engine->enable_patch(patch_path);
break;
}
}
diff --git a/src/libs/serialisation/Loader.hpp b/src/libs/serialisation/Loader.hpp
index a1d4e302..1f9328d2 100644
--- a/src/libs/serialisation/Loader.hpp
+++ b/src/libs/serialisation/Loader.hpp
@@ -25,6 +25,7 @@
#include <raul/Path.hpp>
#include <raul/Table.hpp>
#include "interface/GraphObject.hpp"
+#include "module/World.hpp"
namespace Redland { class World; }
namespace Ingen { namespace Shared { class EngineInterface; } }
@@ -39,14 +40,12 @@ class Loader {
public:
virtual ~Loader() {}
- virtual bool
- load(SharedPtr<Ingen::Shared::EngineInterface> engine,
- Redland::World* world,
- const Glib::ustring& uri,
- boost::optional<Raul::Path> parent,
- std::string patch_name,
- Glib::ustring patch_uri = "",
- GraphObject::Variables data = GraphObject::Variables());
+ virtual bool load(Ingen::Shared::World* world,
+ const Glib::ustring& uri,
+ boost::optional<Raul::Path> parent,
+ std::string patch_name,
+ Glib::ustring patch_uri = "",
+ GraphObject::Variables data = GraphObject::Variables());
};