From 581fe8a23727e1b59a4fd120bfd326f42862b037 Mon Sep 17 00:00:00 2001 From: Paul Davis Date: Fri, 8 Jul 2016 17:09:44 -0400 Subject: add MIDI bundles to Generic MIDI support so that the ports show up nicely in the grid --- .../generic_midi/generic_midi_control_protocol.cc | 31 ++++++++++++++++++++++ .../generic_midi/generic_midi_control_protocol.h | 4 +++ 2 files changed, 35 insertions(+) (limited to 'libs/surfaces/generic_midi') diff --git a/libs/surfaces/generic_midi/generic_midi_control_protocol.cc b/libs/surfaces/generic_midi/generic_midi_control_protocol.cc index d14a9ca24c..10b52027e8 100644 --- a/libs/surfaces/generic_midi/generic_midi_control_protocol.cc +++ b/libs/surfaces/generic_midi/generic_midi_control_protocol.cc @@ -67,6 +67,23 @@ GenericMidiControlProtocol::GenericMidiControlProtocol (Session& s) _input_port = boost::dynamic_pointer_cast (s.midi_input_port ()); _output_port = boost::dynamic_pointer_cast (s.midi_output_port ()); + _input_bundle.reset (new ARDOUR::Bundle (_("Generic MIDI Control In"), true)); + _output_bundle.reset (new ARDOUR::Bundle (_("Generic MIDI Control Out"), false)); + + _input_bundle->add_channel ( + boost::static_pointer_cast(_input_port)->name(), + ARDOUR::DataType::MIDI, + session->engine().make_port_name_non_relative (boost::static_pointer_cast(_input_port)->name()) + ); + + _output_bundle->add_channel ( + boost::static_pointer_cast(_output_port)->name(), + ARDOUR::DataType::MIDI, + session->engine().make_port_name_non_relative (boost::static_pointer_cast(_output_port)->name()) + ); + + session->BundleAddedOrRemoved (); + do_feedback = false; _feedback_interval = 10000; // microseconds last_feedback_time = 0; @@ -110,6 +127,20 @@ GenericMidiControlProtocol::~GenericMidiControlProtocol () tear_down_gui (); } +list > +GenericMidiControlProtocol::bundles () +{ + list > b; + + if (_input_bundle) { + b.push_back (_input_bundle); + b.push_back (_output_bundle); + } + + return b; +} + + static const char * const midimap_env_variable_name = "ARDOUR_MIDIMAPS_PATH"; static const char* const midi_map_dir_name = "midi_maps"; static const char* const midi_map_suffix = ".map"; diff --git a/libs/surfaces/generic_midi/generic_midi_control_protocol.h b/libs/surfaces/generic_midi/generic_midi_control_protocol.h index d3709c5374..ac5b8bdb8f 100644 --- a/libs/surfaces/generic_midi/generic_midi_control_protocol.h +++ b/libs/surfaces/generic_midi/generic_midi_control_protocol.h @@ -55,6 +55,8 @@ class GenericMidiControlProtocol : public ARDOUR::ControlProtocol { int set_active (bool yn); static bool probe() { return true; } + std::list > bundles (); + boost::shared_ptr input_port () const; boost::shared_ptr output_port () const; @@ -106,6 +108,8 @@ class GenericMidiControlProtocol : public ARDOUR::ControlProtocol { PBD::Signal0 ConnectionChange; private: + boost::shared_ptr _input_bundle; + boost::shared_ptr _output_bundle; boost::shared_ptr _input_port; boost::shared_ptr _output_port; -- cgit v1.2.3