SkillAgentSearch skills...

Midir

Cross-platform realtime MIDI processing in Rust.

Install / Use

/learn @Boddlnagg/Midir
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

midir crates.io

Cross-platform, realtime MIDI processing in Rust.

Features

midir is inspired by RtMidi and supports the same features*, including virtual ports (except on Windows) and full SysEx support – but with a rust-y API!

<sup>* With the exception of message queues, but these can be implemented on top of callbacks using e.g. Rust's channels.</sup>

midir currently supports the following platforms/backends:

  • [x] ALSA (Linux)
  • [x] WinMM (Windows)
  • [x] CoreMIDI (macOS, iOS)
  • [x] WinRT (Windows 8+), enable the winrt feature
  • [x] Jack (Linux, macOS), enable the jack feature
  • [x] Web MIDI (Chrome, Opera, perhaps others browsers)
  • [x] Android (API 29+, NDK AMidi + JNI)

A higher-level API for parsing and assembling MIDI messages might be added in the future.

Documentation & Example

API docs can be found at docs.rs. You can find some examples in the examples directory. Or simply run cargo run --example test_play after cloning this repository.

Android

  • Requires Android API 29+ and the Android NDK (r20b+).
  • Build (example, to remove before merging):
    • Install: cargo install cargo-ndk
    • Targets: rustup target add aarch64-linux-android
    • Build: cargo ndk -t arm64-v8a -o ./app/src/main/jniLibs build --release
  • Permissions/features:
    • Manifest should declare <uses-feature android:name="android.software.midi" android:required="false" /> (not needed for USB/BLE MIDI).

Related Skills

View on GitHub
GitHub Stars795
CategoryContent
Updated7d ago
Forks100

Languages

Rust

Security Score

100/100

Audited on Mar 29, 2026

No findings