22 stable releases (4 major)

Uses old Rust 2015

4.0.10 Dec 20, 2023
4.0.8 Aug 30, 2023
4.0.6 May 14, 2021
4.0.4 Feb 18, 2021
0.2.0 Jan 22, 2018

#26 in Audio

Download history 162/week @ 2023-12-24 37/week @ 2023-12-31 89/week @ 2024-01-07 139/week @ 2024-01-14 88/week @ 2024-01-21 60/week @ 2024-01-28 117/week @ 2024-02-04 202/week @ 2024-02-11 499/week @ 2024-02-18 529/week @ 2024-02-25 286/week @ 2024-03-03 120/week @ 2024-03-10 115/week @ 2024-03-17 81/week @ 2024-03-24 476/week @ 2024-03-31 73/week @ 2024-04-07

752 downloads per month
Used in 2 crates (via lv2-midi)

MIT license

80KB
1.5K SLoC

WMIDI

Midi encoding and decoding library.

crates.io docs.rs

License: MIT Build Status

Usage

use std::convert::TryFrom;

// Decoding messages from bytes.
fn handle_midi_message(bytes: &[u8]) -> Result<(), wmidi::FromBytesError> {
    let message = wmidi::MidiMessage::try_from(bytes)?;
    if let wmidi::MidiMessage::NoteOn(_, note, val) = message {
        let volume = u8::from(val) as u8 / 127.0;
        println!("Singing {} at volume {}", note, volume);
    }
    Ok(())
}

// Encoding messages to bytes.
fn midi_to_bytes(message: wmidi::MidiMessage<'_>) -> Vec<u8> {
    let mut bytes = vec![0u8; message.bytes_size()];
    message.copy_to_slice(bytes.as_mut_slice()).unwrap();
    bytes
}

Features

  • Supports no_std environments.
  • No memory allocations (therefore realtime safe) for parsing and encoding.
  • No memory allocations for creating MidiMessage, except for MidiMessage::OwnedSysEx.

Testing & Benchmarking

  • Build with cargo build.
  • Test with cargo test.
  • Benchmark with cargo bench. The results will be under ./target/criterion/report/index.html.

Changelog

4.0.0

  • New ControlFunction type which simply wraps a U7.
  • Constants and documentation for all ControlFunction values.
  • Renumber Note enums/consts to be more consistent with midi; for example, C0 is now C1.

3.1.0

  • Rename MidiMessage::wire_size() to MidiMessage::bytes_size().
  • Introduce MidiMessage::copy_to_slice() method.

3.0.0

  • Instances of U7 and U14 now have bounds checking.
  • Note is now an enum instead of a u8. Can be converted with Note::try_from and u8::from.

No runtime deps