summaryrefslogtreecommitdiff
path: root/libs/ardour/ardour/port_manager.h
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2020-04-06 23:45:36 +0200
committerRobin Gareus <robin@gareus.org>2020-04-06 23:45:36 +0200
commitad0c5f1a1ca0415b2f607363402545d8378a1ddf (patch)
tree57d526e24867b8640ffd4aa5390430e99a2e1c34 /libs/ardour/ardour/port_manager.h
parent597837022a1962261a75234a5000bb237a014852 (diff)
NO-OP: whitespace
Diffstat (limited to 'libs/ardour/ardour/port_manager.h')
-rw-r--r--libs/ardour/ardour/port_manager.h121
1 files changed, 69 insertions, 52 deletions
diff --git a/libs/ardour/ardour/port_manager.h b/libs/ardour/ardour/port_manager.h
index 25497a442f..ddaa50e3c7 100644
--- a/libs/ardour/ardour/port_manager.h
+++ b/libs/ardour/ardour/port_manager.h
@@ -20,10 +20,10 @@
#ifndef __libardour_port_manager_h__
#define __libardour_port_manager_h__
-#include <vector>
-#include <string>
#include <exception>
#include <map>
+#include <string>
+#include <vector>
#include <stdint.h>
@@ -44,58 +44,59 @@ class Session;
class LIBARDOUR_API PortManager
{
- public:
- typedef std::map<std::string,boost::shared_ptr<Port> > Ports;
- typedef std::list<boost::shared_ptr<Port> > PortList;
+public:
+ typedef std::map<std::string, boost::shared_ptr<Port> > Ports;
+ typedef std::list<boost::shared_ptr<Port> > PortList;
PortManager ();
- virtual ~PortManager() {}
+ virtual ~PortManager () {}
- PortEngine& port_engine();
+ PortEngine& port_engine ();
- uint32_t port_name_size() const;
- std::string my_name() const;
+ uint32_t port_name_size () const;
+ std::string my_name () const;
/* Port registration */
boost::shared_ptr<Port> register_input_port (DataType, const std::string& portname, bool async = false, PortFlags extra_flags = PortFlags (0));
boost::shared_ptr<Port> register_output_port (DataType, const std::string& portname, bool async = false, PortFlags extra_flags = PortFlags (0));
- int unregister_port (boost::shared_ptr<Port>);
+ int unregister_port (boost::shared_ptr<Port>);
/* Port connectivity */
- 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 ();
+ 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 ();
- bool connected (const std::string&);
- bool physically_connected (const std::string&);
- int get_connections (const std::string&, std::vector<std::string>&);
+ bool connected (const std::string&);
+ bool physically_connected (const std::string&);
+ int get_connections (const std::string&, std::vector<std::string>&);
/* Naming */
- boost::shared_ptr<Port> get_port_by_name (const std::string &);
+ boost::shared_ptr<Port> get_port_by_name (const std::string&);
void port_renamed (const std::string&, const std::string&);
std::string make_port_name_relative (const std::string& name) const;
std::string make_port_name_non_relative (const std::string& name) const;
std::string get_pretty_name_by_name (const std::string& portname) const;
- std::string short_port_name_from_port_name (std::string const & full_name) const;
+ std::string short_port_name_from_port_name (std::string const& full_name) const;
bool port_is_mine (const std::string& fullname) const;
- static bool port_is_control_only (std::string 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_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>&,
+ 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;
@@ -105,9 +106,15 @@ class LIBARDOUR_API PortManager
void set_port_pretty_name (std::string const&, std::string const&);
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; }
+
+ PBD::RingBuffer<Port*>& port_deletions_pending ()
+ {
+ return _port_deletions_pending;
+ }
bool check_for_amibiguous_latency (bool log = false) const;
@@ -117,26 +124,33 @@ class LIBARDOUR_API PortManager
void request_input_monitoring (const std::string&, bool) const;
void ensure_input_monitoring (const std::string&, bool) const;
- class PortRegistrationFailure : public std::exception {
- public:
- PortRegistrationFailure (std::string const & why = "")
+ class PortRegistrationFailure : public std::exception
+ {
+ public:
+ PortRegistrationFailure (std::string const& why = "")
: reason (why) {}
~PortRegistrationFailure () throw () {}
- const char *what() const throw () { return reason.c_str(); }
+ const char* what () const throw ()
+ {
+ return reason.c_str ();
+ }
- private:
+ private:
std::string reason;
};
/* the port engine will invoke these callbacks when the time is right */
void registration_callback ();
- int graph_order_callback ();
+ int graph_order_callback ();
void connect_callback (const std::string&, const std::string&, bool connection);
- bool port_remove_in_progress() const { return _port_remove_in_progress; }
+ bool port_remove_in_progress () const
+ {
+ return _port_remove_in_progress;
+ }
struct MidiPortInformation {
std::string backend;
@@ -145,24 +159,27 @@ class LIBARDOUR_API PortManager
MidiPortFlags properties;
bool exists;
- MidiPortInformation (std::string const & b, std::string const & pretty, bool input, MidiPortFlags flags, bool xists)
+ MidiPortInformation (std::string const& b, std::string const& pretty, bool input, MidiPortFlags flags, bool xists)
: backend (b)
, pretty_name (pretty)
, input (input)
, properties (flags)
- , exists (xists) {}
+ , exists (xists)
+ {}
+
MidiPortInformation ()
: properties (MidiPortFlags (0))
- , exists (false) {}
+ , exists (false)
+ {}
};
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 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);
/** Emitted if the list of ports to be used for MIDI selection tracking changes */
PBD::Signal0<void> MidiSelectionPortsChanged;
@@ -182,19 +199,21 @@ class LIBARDOUR_API PortManager
*/
PBD::Signal5<void, boost::weak_ptr<Port>, std::string, boost::weak_ptr<Port>, std::string, bool> PortConnectedOrDisconnected;
- protected:
+protected:
boost::shared_ptr<AudioBackend> _backend;
+
SerializedRCUManager<Ports> ports;
- bool _port_remove_in_progress;
+
+ 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);
+ void port_registration_failure (const std::string& portname);
/** List of ports to be used between \ref cycle_start() and \ref cycle_end() */
boost::shared_ptr<Ports> _cycle_ports;
- void silence (pframes_t nframes, Session *s = 0);
+ void silence (pframes_t nframes, Session* s = 0);
void silence_outputs (pframes_t nframes);
void check_monitoring ();
/** Signal the start of an audio cycle.
@@ -212,24 +231,22 @@ class LIBARDOUR_API PortManager
void cycle_end_fade_out (gain_t, gain_t, pframes_t, Session* s = 0);
- typedef std::map<std::string,MidiPortInformation> MidiPortInfo;
+ typedef std::map<std::string, MidiPortInformation> MidiPortInfo;
mutable Glib::Threads::Mutex midi_port_info_mutex;
- MidiPortInfo midi_port_info;
+ 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 ();
+ 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);
void set_port_buffer_sizes (pframes_t);
};
-
-
-} // namespace
+} // namespace ARDOUR
#endif /* __libardour_port_manager_h__ */