21 releases (breaking)

0.17.0 Oct 15, 2024
0.16.0 May 3, 2024
0.15.0 Apr 25, 2024
0.14.0 Aug 12, 2023
0.1.0 Aug 25, 2021

#141 in Audio

Download history 3/week @ 2024-09-18 20/week @ 2024-09-25 13/week @ 2024-10-02 87/week @ 2024-10-09 73/week @ 2024-10-16 4/week @ 2024-10-23 7/week @ 2024-12-04 54/week @ 2024-12-11 42/week @ 2024-12-25

103 downloads per month
Used in ksynth

MIT license

40KB
838 lines

syxpack

Helpers for processing MIDI System Exclusive messages.

Notes about parsing MIDI System Exclusive messages

MIDI System Exclusive messages always start with the status byte 0xF0. Usually they are terminated with the status byte 0xF7, but according to the MIDI specification it can be replaced with any other status byte except a Real-Time message. However, this seems to be quite rare. Still, technically the block between 0xF0 and 0xF7 could contain Timing Clock (0xF8) or Active Sensing (0xFE) messages.

For simplicity, and because these other messages practically never occur in System Exclusive dumps from synthesizers, the SyxPack library only deals with System Exclusive messages as being strictly delimited by 0xF0 and 0xF7.

Some synthesizers pack multiple System Exclusive messages into the same dump. SyxPack assumes that the Vec<u8> passed to Message::new contains only one System Exclusive message delimited by 0xF0 and 0xF7. If there are multiple messages, the payload will end up containing the actual message data and all the other data up to the final terminating 0xF7.

The message_count function returns the number of messages in the byte vector, based on the number of 0xF7 terminator bytes found. If this function returns a value greater than one, you should first split the vector into multiple vectors by the 0xF7 terminator, using the split_messages function:

use syxpack::Message;

let mut all_messages: Vec<Message> = Vec::new();
let count = message_count(buffer.to_vec());
if count >= 1 {
    if count == 1 {
        all_messages.push(Message::new(buffer.to_vec()));
    }
    else {
        let messages = split_messages(buffer.to_vec());
        for message in messages {
            all_messages.push(Message::new(message));
        }
    }
};
println!("Messages found: {}", count);

MIDI manufacturer names

The MIDI manufacturer names are originally from the MIDI Manufacturers' Association (MMA). They are not responsible for any errors or omissions. Then again, any obvious errors have not been corrected either.

Dependencies

~1.1–1.7MB
~32K SLoC