hmidi-0.2.2.1: Binding to the OS level MIDI services

Safe HaskellSafe
LanguageHaskell98

System.MIDI

Contents

Description

A lowest common denominator interface to the Win32 and MacOSX MIDI bindings. Error handling is via fail-s in the IO monad. .

Always link with the threaded runtime! (use the -threaded GHC option)

Synopsis

Documentation

MIDI sources and destionations

type Source = Source Source

The opaque data type representing a MIDI source.

type Destination = Destination Source

The opaque data type representing a MIDI destination.

type Connection = Connection Source

The opaque data type representing a MIDI connection.

enumerateSources :: IO [Source] Source

Enumerates the MIDI sources present in the system.

enumerateDestinations :: IO [Destination] Source

Enumerates the MIDI destinations present in the system.

names of MIDI devices

getName :: MIDIHasName a => a -> IO String Source

These functions return the name, model and manufacturer of a MIDI source / destination.

Note: On Win32, only getName returns a somewhat meaningful string at the moment.

connecting to a MIDI source or destination

openSource :: Source -> Maybe ClientCallback -> IO Connection Source

Opens a MIDI Source. There are two possibilites to receive MIDI messages. The user can either supply a callback function, or get the messages from an asynchronous buffer. However, mixing the two approaches is not allowed.

openDestination :: Destination -> IO Connection Source

Opens a MIDI Destination.

start :: Connection -> IO () Source

Starts a connection. This is required for receiving MIDI messages, and also for starting the clock.

stop :: Connection -> IO () Source

Stops a connection.

close :: Connection -> IO () Source

Closes a MIDI Connection.

sending messages

send :: Connection -> MidiMessage -> IO () Source

Sends a short message. The connection must be a Destination.

sendSysEx :: Connection -> [Word8] -> IO () Source

Sends a system exclusive message. You should not include the starting / trailing bytes 0xF0 and 0xF7.

Note: On Win32, the connection must be a Destination

manual polling of events

getNextEvent :: Connection -> IO (Maybe MidiEvent) Source

Gets the next event from a buffered connection (see also openSource)

checkNextEvent :: Connection -> IO (Maybe MidiEvent) Source

Checks the next event from a buffered connection, but does not remove it from the buffer.

getEvents :: Connection -> IO [MidiEvent] Source

Gets all the events from the buffer (see also openSource)

getEventsUntil :: Connection -> TimeStamp -> IO [MidiEvent] Source

Gets all the events with timestamp less than the specified from the buffer.

querying time

currentTime :: Connection -> IO Word32 Source

Returns the time elapsed since the last start call, in milisecs.