coremidi separate ID and Name, use fixed IDs.
authorRobin Gareus <robin@gareus.org>
Sun, 8 Mar 2015 17:11:38 +0000 (18:11 +0100)
committerRobin Gareus <robin@gareus.org>
Sun, 8 Mar 2015 18:02:31 +0000 (19:02 +0100)
libs/backends/coreaudio/coreaudio_backend.cc
libs/backends/coreaudio/coremidi_io.cc
libs/backends/coreaudio/coremidi_io.h

index d2ffd31d58b853c5bac8d9fd16f3a5a2bd32bb13..f0313f91e0a76b66d480578e23d932e74efb535e 100644 (file)
@@ -968,7 +968,7 @@ CoreAudioBackend::coremidi_rediscover()
        for (std::vector<CoreBackendPort*>::iterator it = _system_midi_out.begin (); it != _system_midi_out.end ();) {
                bool found = false;
                for (size_t i = 0; i < _midiio->n_midi_outputs(); ++i) {
-                       if ((*it)->name() == _midiio->port_name(i, false)) {
+                       if ((*it)->name() == _midiio->port_id(i, false)) {
                                found = true;
                                break;
                        }
@@ -988,7 +988,7 @@ CoreAudioBackend::coremidi_rediscover()
        for (std::vector<CoreBackendPort*>::iterator it = _system_midi_in.begin (); it != _system_midi_in.end ();) {
                bool found = false;
                for (size_t i = 0; i < _midiio->n_midi_inputs(); ++i) {
-                       if ((*it)->name() == _midiio->port_name(i, true)) {
+                       if ((*it)->name() == _midiio->port_id(i, true)) {
                                found = true;
                                break;
                        }
@@ -1006,7 +1006,7 @@ CoreAudioBackend::coremidi_rediscover()
        }
 
        for (size_t i = 0; i < _midiio->n_midi_inputs(); ++i) {
-               std::string name = _midiio->port_name(i, true);
+               std::string name = _midiio->port_id(i, true);
                if (find_port_in(_system_midi_in, name)) {
                        continue;
                }
@@ -1022,12 +1022,14 @@ CoreAudioBackend::coremidi_rediscover()
                LatencyRange lr;
                lr.min = lr.max = _samples_per_period; // TODO add per-port midi-systemic latency
                set_latency_range (p, false, lr);
-               _system_midi_in.push_back(static_cast<CoreBackendPort*>(p));
+               CoreBackendPort *pp = static_cast<CoreBackendPort*>(p);
+               pp->set_pretty_name(_midiio->port_name(i, true));
+               _system_midi_in.push_back(pp);
                _port_change_flag = true;
        }
 
        for (size_t i = 0; i < _midiio->n_midi_outputs(); ++i) {
-               std::string name = _midiio->port_name(i, false);
+               std::string name = _midiio->port_id(i, false);
                if (find_port_in(_system_midi_out, name)) {
                        continue;
                }
@@ -1043,7 +1045,9 @@ CoreAudioBackend::coremidi_rediscover()
                LatencyRange lr;
                lr.min = lr.max = _samples_per_period; // TODO add per-port midi-systemic latency
                set_latency_range (p, false, lr);
-               _system_midi_out.push_back(static_cast<CoreBackendPort*>(p));
+               CoreBackendPort *pp = static_cast<CoreBackendPort*>(p);
+               pp->set_pretty_name(_midiio->port_name(i, false));
+               _system_midi_out.push_back(pp);
                _port_change_flag = true;
        }
 
index 87f88a3a029a05938550e31c322a1ae32c11dc4b..c83d51d7f3d354f892435ef882a44a220ef2bca9 100644 (file)
@@ -43,11 +43,11 @@ static void midiInputCallback(const MIDIPacketList *list, void *procRef, void *s
        }
 }
 
-static std::string getDisplayName(MIDIObjectRef object)
+static std::string getPropertyString (MIDIObjectRef object, CFStringRef key)
 {
        CFStringRef name = nil;
        std::string rv = "";
-       if (noErr == MIDIObjectGetStringProperty(object, kMIDIPropertyDisplayName, &name)) {
+       if (noErr == MIDIObjectGetStringProperty(object, key, &name)) {
                const CFIndex size = CFStringGetMaximumSizeForEncoding(CFStringGetLength(name), kCFStringEncodingUTF8);
                char *tmp = (char*) malloc(size);
                if (CFStringGetCString(name, tmp, size, kCFStringEncodingUTF8)) {
@@ -59,6 +59,10 @@ static std::string getDisplayName(MIDIObjectRef object)
        return rv;
 }
 
+static std::string getDisplayName (MIDIObjectRef object) {
+       return getPropertyString(object, kMIDIPropertyDisplayName);
+}
+
 CoreMidiIo::CoreMidiIo()
        : _midi_client (0)
        , _input_endpoints (0)
@@ -231,28 +235,44 @@ CoreMidiIo::send_event (uint32_t port, double reltime_us, const uint8_t *d, cons
        return 0;
 }
 
+
 std::string
-CoreMidiIo::port_name (uint32_t port, bool input)
+CoreMidiIo::port_id (uint32_t port, bool input)
 {
        std::stringstream ss;
-       std::string pn;
-       // XXX including the number will not yield persistent port-names
-       // when disconnecting devices in the middle.
        if (input) {
-               ss << "system:midi_capture_" << port;
+               ss << "system:midi_capture_";
+               SInt32 id;
+               if (noErr == MIDIObjectGetIntegerProperty(_input_endpoints[port], kMIDIPropertyUniqueID, &id)) {
+                       ss << (int)id;
+               } else {
+                       ss << port;
+               }
+       } else {
+               ss << "system:midi_playback_";
+               SInt32 id;
+               if (noErr == MIDIObjectGetIntegerProperty(_output_endpoints[port], kMIDIPropertyUniqueID, &id)) {
+                       ss << (int)id;
+               } else {
+                       ss << port;
+               }
+       }
+       return ss.str();
+}
+
+std::string
+CoreMidiIo::port_name (uint32_t port, bool input)
+{
+       if (input) {
                if (port < _n_midi_in) {
-                       pn = getDisplayName(_input_endpoints[port]);
+                       return getDisplayName(_input_endpoints[port]);
                }
        } else {
-               ss << "system:midi_playback_" << port;
                if (port < _n_midi_out) {
-                       pn = getDisplayName(_output_endpoints[port]);
+                       return getDisplayName(_output_endpoints[port]);
                }
        }
-       if (!pn.empty()) {
-               ss << " - " << pn;
-       }
-       return ss.str();
+       return "";
 }
 
 void
index de4f9be0bb2aac01acc5ef96db9e1d1ea7952d67..e74b495f7c783595d3cd56cdd6270d3246dffcd4 100644 (file)
@@ -74,6 +74,7 @@ public:
 
        uint32_t n_midi_inputs (void) const { return _n_midi_in; }
        uint32_t n_midi_outputs (void) const { return _n_midi_out; }
+       std::string port_id (uint32_t, bool input);
        std::string port_name (uint32_t, bool input);
 
        void notify_proc (const MIDINotification *message);