summaryrefslogtreecommitdiffstats
path: root/src/client/PluginModel.cpp
diff options
context:
space:
mode:
authorDavid Robillard <d@drobilla.net>2015-08-12 04:46:29 +0000
committerDavid Robillard <d@drobilla.net>2015-08-12 04:46:29 +0000
commitdd79e76e41446833088482588456afed37231bff (patch)
treec0f3c5c2fc74b286d529df69ad2206e2fddd96f9 /src/client/PluginModel.cpp
parent44af7b7b66e2083819103c760ab3bf4980469f86 (diff)
downloadingen-dd79e76e41446833088482588456afed37231bff.tar.gz
ingen-dd79e76e41446833088482588456afed37231bff.tar.bz2
ingen-dd79e76e41446833088482588456afed37231bff.zip
Server-side presets.
git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@5703 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src/client/PluginModel.cpp')
-rw-r--r--src/client/PluginModel.cpp27
1 files changed, 17 insertions, 10 deletions
diff --git a/src/client/PluginModel.cpp b/src/client/PluginModel.cpp
index f228863c..3a1f3a9a 100644
--- a/src/client/PluginModel.cpp
+++ b/src/client/PluginModel.cpp
@@ -42,28 +42,28 @@ Sord::World* PluginModel::_rdf_world = NULL;
PluginModel::PluginModel(URIs& uris,
const Raul::URI& uri,
- const Raul::URI& type_uri,
+ const Atom& type,
const Resource::Properties& properties)
- : Plugin(uris, uri)
- , _type(type_from_uri(type_uri))
+ : Resource(uris, uri)
+ , _type(type)
+ , _fetched(false)
{
- if (_type == NIL) {
+ if (!_type.is_valid()) {
if (uri.find("ingen-internals") != string::npos) {
- _type = Internal;
+ _type = uris.ingen_Internal;
} else {
- _type = LV2; // Assume LV2 and hope Lilv can tell us something
+ _type = uris.lv2_Plugin; // Assume LV2 and hope for the best...
}
}
+
+ add_property(uris.rdf_type, type);
add_properties(properties);
- assert(_rdf_world);
- add_property(uris.rdf_type,
- uris.forge.alloc_uri(this->type_uri()));
LilvNode* plugin_uri = lilv_new_uri(_lilv_world, uri.c_str());
_lilv_plugin = lilv_plugins_get_by_uri(_lilv_plugins, plugin_uri);
lilv_node_free(plugin_uri);
- if (_type == Internal) {
+ if (uris.ingen_Internal == _type) {
set_property(uris.doap_name,
uris.forge.alloc(uri.substr(uri.find_last_of('#') + 1)));
}
@@ -166,6 +166,13 @@ PluginModel::set(SPtr<PluginModel> p)
_signal_changed.emit();
}
+void
+PluginModel::add_preset(const Raul::URI& uri, const std::string& label)
+{
+ _presets.insert(std::make_pair(uri, label));
+ _signal_preset.emit(uri, label);
+}
+
Raul::Symbol
PluginModel::default_block_symbol() const
{