From 44b7830064d732cff4f0e55babcc47fccda2245e Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Wed, 7 Sep 2011 14:42:25 +0000 Subject: [PATCH] Set up ControlUI::combo_map correctly to fix drop-down boxes in generated plugin UIs (#4221). Based on work by jeremybub. git-svn-id: svn://localhost/ardour2/branches/3.0@10064 d708f5d6-7413-0410-9779-e7cbd77b26cf --- gtk2_ardour/generic_pluginui.cc | 19 +++++++++---------- gtk2_ardour/plugin_ui.h | 2 +- 2 files changed, 10 insertions(+), 11 deletions(-) diff --git a/gtk2_ardour/generic_pluginui.cc b/gtk2_ardour/generic_pluginui.cc index 64b1ac344c..6bdd8314b9 100644 --- a/gtk2_ardour/generic_pluginui.cc +++ b/gtk2_ardour/generic_pluginui.cc @@ -481,7 +481,6 @@ GenericPluginUI::build_control_ui (guint32 port_index, boost::shared_ptrcombo = 0; - control_ui->combo_map = 0; control_ui->control = mcontrol; control_ui->update_pending = false; control_ui->label.set_text (desc.label); @@ -497,13 +496,15 @@ GenericPluginUI::build_control_ui (guint32 port_index, boost::shared_ptr points - = plugin->get_scale_points(port_index); + control_ui->combo_map = plugin->get_scale_points (port_index); - if (points) { + if (control_ui->combo_map) { std::vector labels; - for (ARDOUR::Plugin::ScalePoints::const_iterator i = points->begin(); - i != points->end(); ++i) { + for ( + ARDOUR::Plugin::ScalePoints::const_iterator i = control_ui->combo_map->begin(); + i != control_ui->combo_map->end(); + ++i) { + labels.push_back(i->first); } @@ -744,8 +745,7 @@ GenericPluginUI::update_control_display (ControlUI* cui) cui->ignore_change++; if (cui->combo && cui->combo_map) { - std::map::iterator it; - for (it = cui->combo_map->begin(); it != cui->combo_map->end(); ++it) { + for (ARDOUR::Plugin::ScalePoints::iterator it = cui->combo_map->begin(); it != cui->combo_map->end(); ++it) { if (it->second == val) { cui->combo->set_active_text(it->first); break; @@ -789,8 +789,7 @@ GenericPluginUI::control_combo_changed (ControlUI* cui) { if (!cui->ignore_change && cui->combo_map) { string value = cui->combo->get_active_text(); - std::map mapping = *cui->combo_map; - insert->automation_control(cui->parameter())->set_value(mapping[value]); + insert->automation_control (cui->parameter())->set_value ((*cui->combo_map)[value]); } } diff --git a/gtk2_ardour/plugin_ui.h b/gtk2_ardour/plugin_ui.h index 4ce7faf376..7c88b01bbd 100644 --- a/gtk2_ardour/plugin_ui.h +++ b/gtk2_ardour/plugin_ui.h @@ -212,7 +212,7 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox /* input */ Gtk::ComboBoxText* combo; - std::map* combo_map; + boost::shared_ptr combo_map; Gtk::ToggleButton* button; boost::shared_ptr controller; Gtkmm2ext::ClickBox* clickbox; -- 2.30.2