summaryrefslogtreecommitdiff
path: root/gtk2_ardour/lv2_plugin_ui.cc
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2018-11-21 02:26:33 +0100
committerRobin Gareus <robin@gareus.org>2018-11-21 02:27:18 +0100
commit07beca2852333aabc5a1828a3a45643765f6ce2d (patch)
treedb4f63c35caf811db0ee285df38d106e3478dbc7 /gtk2_ardour/lv2_plugin_ui.cc
parenta4d6f0ea396bf8f33191f303ad3416214746411e (diff)
Early prototype for _LV2UI_Request_Parameter extension
Diffstat (limited to 'gtk2_ardour/lv2_plugin_ui.cc')
-rw-r--r--gtk2_ardour/lv2_plugin_ui.cc84
1 files changed, 66 insertions, 18 deletions
diff --git a/gtk2_ardour/lv2_plugin_ui.cc b/gtk2_ardour/lv2_plugin_ui.cc
index 3ed95c7e98..b0290e0d73 100644
--- a/gtk2_ardour/lv2_plugin_ui.cc
+++ b/gtk2_ardour/lv2_plugin_ui.cc
@@ -26,6 +26,8 @@
#include "lv2_plugin_ui.h"
#include "timers.h"
+#include "gtkmm2ext/utils.h"
+
#include "lv2/lv2plug.in/ns/extensions/ui/ui.h"
#include <lilv/lilv.h>
@@ -112,6 +114,45 @@ LV2PluginUI::touch(void* controller,
}
}
+uint32_t
+LV2PluginUI::request_parameter (void* handle, LV2_URID key)
+{
+ LV2PluginUI* me = (LV2PluginUI*)handle;
+
+ /* This will return `PropertyDescriptors nothing` when not found */
+ const ParameterDescriptor& desc (me->_lv2->get_property_descriptor(key));
+ if (desc.datatype != Variant::PATH) {
+ return -1;
+ }
+
+ // TODO: check if window for current URID already exists -> return -1;
+ // Create and show window, subscribe to file-selected signal
+ // then return 0; don't block here.
+
+ Gtk::FileChooserDialog lv2ui_file_dialog (desc.label, FILE_CHOOSER_ACTION_OPEN);
+ Gtkmm2ext::add_volume_shortcuts (lv2ui_file_dialog);
+
+ /* LV2Plugin does not currently save property values and only
+ * emits a PropertyChanged(urid, Variant) signal
+ */
+ //lv2ui_file_dialog.set_current_folder (TODO)
+
+#if 0 // TODO mime-type,
+ FileFilter file_ext_filter;
+ file_ext_filter.add_pattern ("*.foo");
+ file_ext_filter.set_name ("Foo File");
+ lv2ui_file_dialog.add_filter (file_ext_filter);
+#endif
+ int response = lv2ui_file_dialog.run();
+ lv2ui_file_dialog.hide ();
+
+ if (response == Gtk::RESPONSE_OK) {
+ me->plugin->set_property (desc.key, Variant(Variant::PATH, lv2ui_file_dialog.get_filename()));
+ }
+
+ return 0;
+}
+
void
LV2PluginUI::update_timeout()
{
@@ -259,9 +300,27 @@ LV2PluginUI::lv2ui_instantiate(const std::string& title)
LV2_Feature** features = const_cast<LV2_Feature**>(_lv2->features());
size_t features_count = 0;
while (*features++) {
- features_count++;
+ ++features_count;
+ }
+
+ if (is_external_ui) {
+ features = (LV2_Feature**)malloc(sizeof(LV2_Feature*) * (features_count + 4));
+ } else {
+ features = (LV2_Feature**)malloc(sizeof(LV2_Feature*) * (features_count + 3));
+ }
+
+ size_t fi = 0;
+ for (; fi < features_count; ++fi) {
+ features[fi] = features_src[fi];
}
+ _lv2ui_request_paramater.handle = this;
+ _lv2ui_request_paramater.request = LV2PluginUI::request_parameter;
+ _lv2ui_request_feature.URI = LV2_EXTERNAL_UI_URI;
+ _lv2ui_request_feature.data = &_lv2ui_request_paramater;
+
+ features[fi++] = &_lv2ui_request_feature;
+
Gtk::Alignment* container = NULL;
if (is_external_ui) {
_external_ui_host.ui_closed = LV2PluginUI::on_external_ui_closed;
@@ -273,15 +332,8 @@ LV2PluginUI::lv2ui_instantiate(const std::string& title)
_external_kxui_feature.URI = LV2_EXTERNAL_UI_KX__Host;
_external_kxui_feature.data = &_external_ui_host;
- ++features_count;
- features = (LV2_Feature**)malloc(
- sizeof(LV2_Feature*) * (features_count + 2));
- for (size_t i = 0; i < features_count - 2; ++i) {
- features[i] = features_src[i];
- }
- features[features_count - 2] = &_external_kxui_feature;
- features[features_count - 1] = &_external_ui_feature;
- features[features_count] = NULL;
+ features[fi++] = &_external_kxui_feature;
+ features[fi++] = &_external_ui_feature;
} else {
if (_ardour_buttons_box.get_parent()) {
_ardour_buttons_box.get_parent()->remove(_ardour_buttons_box);
@@ -296,16 +348,12 @@ LV2PluginUI::lv2ui_instantiate(const std::string& title)
_parent_feature.URI = LV2_UI__parent;
_parent_feature.data = _gui_widget->gobj();
- ++features_count;
- features = (LV2_Feature**)malloc(
- sizeof(LV2_Feature*) * (features_count + 1));
- for (size_t i = 0; i < features_count - 1; ++i) {
- features[i] = features_src[i];
- }
- features[features_count - 1] = &_parent_feature;
- features[features_count] = NULL;
+ features[fi++] = &_parent_feature;
}
+ features[fi] = NULL;
+ assert (fi == features_count + (is_external_ui ? 3 : 2));
+
if (!ui_host) {
ui_host = suil_host_new(LV2PluginUI::write_from_ui,
LV2PluginUI::port_index,