Skip to content
MIDI apps for Mac OS X: MIDI Monitor and SysEx Librarian.
Objective-C C++ HTML C Rich Text Format
Branch: master
Clone or download
krevis Tweak naming of autoconnect options.
Make default migration happen before the prefs windows can appear, so can't show something that's out of sync.
Pick the frontmost document if there is no document with a key or main window (e.g. if the app is in the background).
Latest commit ffda16d Jul 7, 2019
Type Name Latest commit message Commit time
Failed to load latest commit information.
Configurations Set ALWAYS_SEARCH_USER_PATHS = NO for everything Aug 5, 2018
Frameworks copyright dates Sep 10, 2018
MIDIApps.xcworkspace Let Xcode update project settings Sep 3, 2018
ThirdParty Bump Sparkle to 1.20.0 release Aug 5, 2018
Updates tweak appcasts Sep 22, 2018
.gitignore Ignore new Xcode 7 *.xcscmblueprint Sep 21, 2015
.gitmodules Update Sparkle, and update config to require 10.7 and 64-bit because … Aug 10, 2014
LICENSE update date Aug 19, 2014 update Sep 16, 2018

What is this?

MIDI Monitor is a Mac OS X application for monitoring MIDI data as it goes in and out of the computer.

SysEx Librarian is a Mac OS X application for sending and receiving MIDI system exclusive (aka sysex) messages.

This is the source code for the two applications. You do not need any of this if you just want to use the apps. You need the source if you want to play with the code, customize the application, or use parts of the code in your own project.

The source code is Open Source under the BSD license. See LICENSE for the legal details.

How to build

  1. git submodule update --init --recursive
  2. Open MIDIApps.xcworkspace with Xcode.
  3. In the "Scheme" popup menu in the toolbar, select either MIDI Monitor or SysEx Librarian.
  4. Build and run!

What's inside

Your source tree should look like this:

  • Applications
    • MIDIMonitor
    • SysExLibrarian
  • Configurations
  • Frameworks
    • SnoizeMIDI
    • SnoizeMIDISpy
  • Third Party
  • Updates

Applications/MIDIMonitor Applications/SysExLibrarian

The source for the two apps. The project files are MIDIMonitor.xcodeproj and SysExLibrarian.xcodeproj; open them with Xcode.

Both apps are Cocoa and are written in Objective-C.

The apps rely on the other frameworks, described below.


A framework containing code for dealing with CoreMIDI in a Cocoa app:

  • Finding MIDI devices, sources, and destinations
  • Creating "streams" of input and output data
  • Hooking them up to inputs and outputs
  • Parsing incoming MIDI data into separate messages

This framework is used by both apps. You can use it in your own apps as well.

The code is mainly Objective-C, with one ordinary C file.


This project builds two things: A CoreMIDI driver, and a framework.

The CoreMIDI driver can "spy" on the MIDI sent to any destination in the system by any app. (See the MIDIDriverEnableMonitoring() function in CoreMIDIServer/MIDIDriver.h for more details.) The driver can then pass the MIDI data to another application.

The framework is used by apps that want to spy. It manages the communication between the app and the driver, and provides the app with an easy way to install the CoreMIDI driver when necessary.

This code is currently only used by MIDI Monitor, but it could be useful in other contexts. MIDI Monitor contains some code to channel the "spy" MIDI data into the rest of the SnoizeMIDI stream system, so it acts just like any other MIDI source.

The driver is written in C++, and the framework is C and Objective-C. You should be able to easily use the code from an application.


Contains .xcconfig files used to coordinate build settings across all the Xcode projects.

Third Party, Updates

Contains the git submodule for Sparkle (the ubiquitous app-auto-update framework) and the server-side files to make it work.

If you don't see the Sparkle submodule, do a git submodule update --init --recursive.


Please contact Kurt Revis with any questions.

You can’t perform that action at this time.