This class contains a number of static helper functions for reading information from Universal MIDI Packets, and also manipulating that information.
In most cases, the calling application needs to do some validation before calling functions which return specific fields. If, for example, the application asks for the Flex Data Status, but doesn’t provide a valid Flex Data message, the function will happily return whatever other data is in the position of that field.
Validation Functions
Function
Description
ValidateMessage32MessageType(word0)
Validate that the message type field in the word is for a 32-bit UMP
ValidateMessage64MessageType(word0)
Validate that the message type field in the word is for a 64-bit UMP
ValidateMessage96MessageType(word0)
Validate that the message type field in the word is for a 96-bit UMP
ValidateMessage128MessageType(word0)
Validate that the message type field in the word is for a 128-bit UMP
Informational Functions
Function
Description
MessageTypeHasGroupField(messageType)
Returns true if the message type is known to be one which contains a group field. Valid only for message types known at the type the API was written.
MessageTypeHasChannelField(messageType)
Returns true if the message type is known to be one which contains a channel field. Valid only for message types known at the type the API was written.
Field Access Functions
Function
Description
GetMessageTypeFromMessageFirstWord(word0)
Returns the MidiMessageType for the message
GetPacketTypeFromMessageFirstWord(word0)
Returns the MidiPacketType for the message
GetGroupFromMessageFirstWord(word0)
Returns the MidiGroup for the message. First check to see if the message type has a group field.
GetChannelFromMessageFirstWord(word0)
Returns the MidiChannel for the message. First check to see if the message type has a channel field.
GetStatusFromUtilityMessage(word0)
Returns the status byte
GetStatusFromMidi1ChannelVoiceMessage(word0)
When provided a MIDI 1.0 channel voice message, returns the Midi1ChannelVoiceMessageStatus for the message.
Replaces the channel field in word0 and returns the resulting MIDI word
Additional Functions
Function
Description
GetMessageDisplayNameFromFirstWord(UInt32 word0)
Returns the localized “Friendly Name” string for a message. For example, this is what is displayed in the console output when you are monitoring an endpoint in verbose mode.