Funky MIDI with libremidi

libremidi is an all-in-one cross-platform C++20 MIDI library for both file and real-time output. Real-time I/O supports MIDI 2 on macOS (11+) and Linux (Kernel 6.5+), and soon on Windows (the OS does not support it yet).

It is a fork / rewrite originally based on two libraries, but has since then almost been entirely rewritten:

Compared to its origins, it features a lot of changes and improvements:

  • libremidi::observer provides hotplug support.
  • Ports are identified not with a number but with a handle which enables more stability when unplugging / replugging.
  • Memory allocations and virtual function calls are greatly reduced when compared to the RtMidi base-line.
    • Ability to enforce fixed message sizes with boost::static_vector for hard real-time operation
    • Ability to use boost::small_vector to cover most cases.
  • Integer timestamps everywhere, by default in nanoseconds.
  • Ability to choose different timestamping methods (e.g. relative, absolute monotonic clock, sample-based or custom timestamping...).
  • Integration of modern C++20 types (for instance std::span instead of std::vector, std::function for callbacks, etc.)
  • Standard C++ threading primitives (std::thread, std::jthread) are now used, as well as modern Linux facilities for polling control (eventfd, timerfd).
  • Most of the code has been refactored in multiple files for clarity.

It also features some new & improved backends:

  • ALSA RawMidi API.
  • PipeWire.
  • Windows UWP.
  • WebMIDI in Emscripten.
  • JACK support on all platforms where it is available.