diff --git a/modules/juce_audio_devices/midi_io/juce_MidiDevices.cpp b/modules/juce_audio_devices/midi_io/juce_MidiDevices.cpp index 23b02c6541..0261793442 100644 --- a/modules/juce_audio_devices/midi_io/juce_MidiDevices.cpp +++ b/modules/juce_audio_devices/midi_io/juce_MidiDevices.cpp @@ -98,6 +98,11 @@ void MidiOutput::sendBlockOfMessages (const MidiBuffer& buffer, notify(); } +bool MidiOutput::hasPendingMessages() const +{ + return firstMessage != nullptr; +} + void MidiOutput::clearAllPendingMessages() { const ScopedLock sl (lock); diff --git a/modules/juce_audio_devices/midi_io/juce_MidiDevices.h b/modules/juce_audio_devices/midi_io/juce_MidiDevices.h index b7ba68d01b..b07558d23c 100644 --- a/modules/juce_audio_devices/midi_io/juce_MidiDevices.h +++ b/modules/juce_audio_devices/midi_io/juce_MidiDevices.h @@ -420,6 +420,9 @@ public: void sendBlockOfMessages (const MidiBuffer& buffer, double millisecondCounterToStartAt, double samplesPerSecondForBuffer); + + /** Returns true if there are pending midi messages */ + bool hasPendingMessages() const; /** Gets rid of any midi messages that had been added by sendBlockOfMessages(). */ void clearAllPendingMessages();