diff options
author | Robin Gareus <robin@gareus.org> | 2014-01-22 23:59:24 +0100 |
---|---|---|
committer | Robin Gareus <robin@gareus.org> | 2014-01-22 23:59:24 +0100 |
commit | 8ad30bb76ed9d90ce3f8e4698ec68a425067a3a9 (patch) | |
tree | 8620176ecde4daf86414804017edd3644e9cef38 /gtk2_ardour | |
parent | f0b95950eefb7c95e2ae1c8e885faac8ca8aa592 (diff) |
configurable midi audition synth
Diffstat (limited to 'gtk2_ardour')
-rw-r--r-- | gtk2_ardour/rc_option_editor.cc | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/gtk2_ardour/rc_option_editor.cc b/gtk2_ardour/rc_option_editor.cc index 4085ffa934..fc69782757 100644 --- a/gtk2_ardour/rc_option_editor.cc +++ b/gtk2_ardour/rc_option_editor.cc @@ -35,6 +35,7 @@ #include "ardour/dB.h" #include "ardour/rc_configuration.h" #include "ardour/control_protocol_manager.h" +#include "ardour/plugin_manager.h" #include "control_protocol/control_protocol.h" #include "ardour_window.h" @@ -1816,6 +1817,31 @@ RCOptionEditor::RCOptionEditor () sigc::mem_fun (*_rc_config, &RCConfiguration::set_sound_midi_notes) )); + add_option (_("MIDI"), new OptionEditorHeading (_("Midi Audition"))); + + ComboOption<std::string>* audition_synth = new ComboOption<std::string> ( + "midi-audition-synth-uri", + _("Midi Audition Synth (LV2)"), + sigc::mem_fun (*_rc_config, &RCConfiguration::get_midi_audition_synth_uri), + sigc::mem_fun (*_rc_config, &RCConfiguration::set_midi_audition_synth_uri) + ); + + audition_synth->add(X_(""), _("None")); + PluginInfoList all_plugs; + PluginManager& manager (PluginManager::instance()); +#ifdef LV2_SUPPORT + all_plugs.insert (all_plugs.end(), manager.lv2_plugin_info().begin(), manager.lv2_plugin_info().end()); + + for (PluginInfoList::const_iterator i = all_plugs.begin(); i != all_plugs.end(); ++i) { + if (manager.get_status (*i) == PluginManager::Hidden) continue; + if (!(*i)->is_instrument()) continue; + if ((*i)->type != ARDOUR::LV2) continue; + audition_synth->add((*i)->unique_id, (*i)->name); + } +#endif + + add_option (_("MIDI"), audition_synth); + /* USER INTERACTION */ if (getenv ("ARDOUR_BUNDLED")) { |