summaryrefslogtreecommitdiff
path: root/libs/backends/coreaudio/coreaudio_backend.h
diff options
context:
space:
mode:
Diffstat (limited to 'libs/backends/coreaudio/coreaudio_backend.h')
-rw-r--r--libs/backends/coreaudio/coreaudio_backend.h23
1 files changed, 13 insertions, 10 deletions
diff --git a/libs/backends/coreaudio/coreaudio_backend.h b/libs/backends/coreaudio/coreaudio_backend.h
index 11e8445ab5..6153b12e10 100644
--- a/libs/backends/coreaudio/coreaudio_backend.h
+++ b/libs/backends/coreaudio/coreaudio_backend.h
@@ -82,7 +82,7 @@ class CoreBackendPort {
bool is_connected (const CoreBackendPort *port) const;
bool is_physically_connected () const;
- const std::vector<CoreBackendPort *>& get_connections () const { return _connections; }
+ const std::set<CoreBackendPort *>& get_connections () const { return _connections; }
int connect (CoreBackendPort *port);
int disconnect (CoreBackendPort *port);
@@ -114,7 +114,7 @@ class CoreBackendPort {
const PortFlags _flags;
LatencyRange _capture_latency_range;
LatencyRange _playback_latency_range;
- std::vector<CoreBackendPort*> _connections;
+ std::set<CoreBackendPort*> _connections;
void _connect (CoreBackendPort* , bool);
void _disconnect (CoreBackendPort* , bool);
@@ -461,12 +461,16 @@ class CoreAudioBackend : public AudioBackend {
int register_system_audio_ports ();
void unregister_ports (bool system_only = false);
- std::vector<CoreBackendPort *> _ports;
std::vector<CoreBackendPort *> _system_inputs;
std::vector<CoreBackendPort *> _system_outputs;
std::vector<CoreBackendPort *> _system_midi_in;
std::vector<CoreBackendPort *> _system_midi_out;
+ typedef std::map<std::string, CoreBackendPort *> PortMap; // fast lookup in _ports
+ typedef std::set<CoreBackendPort *> PortIndex; // fast lookup in _ports
+ PortMap _portmap;
+ PortIndex _ports;
+
struct PortConnectData {
std::string a;
std::string b;
@@ -493,16 +497,15 @@ class CoreAudioBackend : public AudioBackend {
}
bool valid_port (PortHandle port) const {
- return std::find (_ports.begin (), _ports.end (), (CoreBackendPort*)port) != _ports.end ();
+ return _ports.find (static_cast<CoreBackendPort*>(port)) != _ports.end ();
}
- CoreBackendPort * find_port (const std::string& port_name) const {
- for (std::vector<CoreBackendPort*>::const_iterator it = _ports.begin (); it != _ports.end (); ++it) {
- if ((*it)->name () == port_name) {
- return *it;
- }
+ CoreBackendPort* find_port (const std::string& port_name) const {
+ PortMap::const_iterator it = _portmap.find (port_name);
+ if (it == _portmap.end()) {
+ return NULL;
}
- return NULL;
+ return (*it).second;
}
CoreBackendPort * find_port_in (std::vector<CoreBackendPort *> plist, const std::string& port_name) const {