#include <boost/shared_ptr.hpp>
#include "pbd/rcu.h"
+#include "pbd/ringbuffer.h"
#include "ardour/chan_count.h"
#include "ardour/midiport_manager.h"
int connect (const std::string& source, const std::string& destination);
int disconnect (const std::string& source, const std::string& destination);
int disconnect (boost::shared_ptr<Port>);
+ int disconnect (std::string const &);
int reestablish_ports ();
int reconnect_ports ();
std::string get_pretty_name_by_name (const std::string& portname) const;
bool port_is_mine (const std::string& fullname) const;
+ static bool port_is_control_only (std::string const &);
+
/* other Port management */
bool port_is_physical (const std::string&) const;
- void get_physical_outputs (DataType type, std::vector<std::string>&);
- void get_physical_inputs (DataType type, std::vector<std::string>&);
+ void get_physical_outputs (DataType type, std::vector<std::string>&,
+ MidiPortFlags include = MidiPortFlags (0),
+ MidiPortFlags exclude = MidiPortFlags (0));
+ void get_physical_inputs (DataType type, std::vector<std::string>&,
+ MidiPortFlags include = MidiPortFlags (0),
+ MidiPortFlags exclude = MidiPortFlags (0));
ChanCount n_physical_outputs () const;
ChanCount n_physical_inputs () const;
int get_ports (DataType, PortList&);
void remove_all_ports ();
+ void clear_pending_port_deletions ();
+ virtual void add_pending_port_deletion (Port*) = 0;
+ PBD::RingBuffer<Port*>& port_deletions_pending () { return _port_deletions_pending; }
/* per-Port monitoring */
bool port_remove_in_progress() const { return _port_remove_in_progress; }
+ struct MidiPortInformation {
+ std::string pretty_name;
+ bool input;
+ MidiPortFlags properties;
+
+ MidiPortInformation () : input (false) , properties (MidiPortFlags (0)) {}
+ };
+
+ void fill_midi_port_info ();
+
+ MidiPortInformation midi_port_information (std::string const&);
+ void get_known_midi_ports (std::vector<std::string>&);
+ void get_midi_selection_ports (std::vector<std::string>&);
+ void add_midi_port_flags (std::string const&, MidiPortFlags);
+ void remove_midi_port_flags (std::string const&, MidiPortFlags);
+ void set_midi_port_pretty_name (std::string const&, std::string const&);
+
+ /** Emitted if the list of ports to be used for MIDI selection tracking changes */
+ PBD::Signal0<void> MidiSelectionPortsChanged;
+ /** Emitted if anything other than the selection property for a MIDI port changes */
+ PBD::Signal0<void> MidiPortInfoChanged;
+
/** Emitted if the backend notifies us of a graph order event */
PBD::Signal0<void> GraphReordered;
boost::shared_ptr<AudioBackend> _backend;
SerializedRCUManager<Ports> ports;
bool _port_remove_in_progress;
+ PBD::RingBuffer<Port*> _port_deletions_pending;
boost::shared_ptr<Port> register_port (DataType type, const std::string& portname, bool input, bool async = false, PortFlags extra_flags = PortFlags (0));
void port_registration_failure (const std::string& portname);
* Realtime safe.
*/
void cycle_end (pframes_t nframes);
+
+ typedef std::map<std::string,MidiPortInformation> MidiPortInfo;
+
+ mutable Glib::Threads::Mutex midi_port_info_mutex;
+ MidiPortInfo midi_port_info;
+
+ static std::string midi_port_info_file ();
+ bool midi_info_dirty;
+ void save_midi_port_info ();
+ void load_midi_port_info ();
+ void fill_midi_port_info_locked ();
+
+ void filter_midi_ports (std::vector<std::string>&, MidiPortFlags, MidiPortFlags);
};