Skip to content

Latest commit

 

History

History
86 lines (70 loc) · 5.63 KB

MIDI-CI.md

File metadata and controls

86 lines (70 loc) · 5.63 KB

MIDI-CI support in ktmidi

Overview

ktmidi has comprehensive MIDI-CI support as well as its dogfooding "ktmidi-ci-tool". They are almost feature complete. The features include:

  • All those MIDI-CI SysEx messages that MIDI-CI version 1.2 specification defines
  • Profile Configuration
    • Initiator can query the profiles on the connected device
    • Responder can configure its own profile settings
    • Set Profile On/Off with Enabled/Disabled Reports
    • Profile Details inquiry (results are visible on the logs)
  • Property Exchange
    • Get, Set, and Subscribe to property (also unsubscribing from it), with corresponding notifications.
    • Metadata system based on Common Rules for Property Exchange version 1.1 specification.
    • mediaType aware content editor on either TextField or binary file uploads
    • Partial value updates based on RFC 6901 (JSON Pointer), and of course, full updates too, as per Common Rules for PE specification, section 8.
    • Paginated list queries as per Common Rules for PE specification, section 6.6.2.
    • mutualEncoding: ASCII, Mcoded7, and zlib+Mcoded7 (to be implemented ubiquitously)
  • Process Inquiry
    • implemented everything in logic, along with Midi1Machine or Midi2Machine in ktmidi module
    • actual implementation in ktmidi-ci-tool is only for MIDI 1.0 bytestream
    • UI is only for requesting. Responses are simply logged (although nicely chunked)
  • Both Profile Configuration and Property Exchange are designed to be MIDI-CI core version agnostic in ktmidi-ci module
    • if those "Common Rules" specification or any alternatives are published then those client and hosting features can be upgraded independent of the Core implementation.
  • Transport agnostic: MIDI-CI support resides in its own ktmidi-ci module, which does not depend on ktmidi.
    • We could make it to send arbitrary SMF (Midi1Music) or MIDI Clip File (Midi2Track maybe), we just need app implementation...
  • UMP support: we support both MIDI 1.0 bytestream and MIDI 2.0 UMP. Note that the actual platform MIDI access is done via MidiAccess and so far only Android is known to work.

Known missing features

  • App lifecycle management: #59
  • zlib+Mcoded7 support on some platforms: ubiquitous zlib implementation is currently on hold until ktor-io 3.0.0 comes up on Kotlin/Wasm. Also, I cannot find any implementation that has no issues. #58
  • Profile specific messages on UI
  • Any timer based session management (i.e. no timeouts implemented)
    • Therefore, no request ID management; it simply increments within Byte #57

Code Structure

Modules:

  • ktmidi-ci implements the actor model as well as CI message serialization.
    • Targets jvm, android, js (IR), wasmJs (experimental), and Kotlin/Native platforms including iOS.
    • It is designed to NOT have ktmidi as a dependency, so far.
  • ktmidi-ci-tool is a Compose Multiplatform app that wraps ktmidi-ci models within the observable repository and views (views includes view models here).
    • No particular architecture model applied yet. Probably Essenty if I choose one.
    • Targets JVM desktop, Android, iOS, and wasm/JS. Not covering Kotlin/Native, JS (non-wasm), and wasmWasi (should match what Compose Multiplatform covers)
    • iOS has no MidiAccess implementation, so while the UI runs, the app itself is useless so far. CoreMidiAccess work in progress (but not in high priority).

Classes:

  • In ktmidi-ci module:
    • MidiCIDevice plays the primary role. It works as the facade for most of the MIDI-CI features.
    • ClientConnection represents a destination MIDI-CI device connection, as the client point of view.
    • Message and all those subclasses represent MIDI-CI SysEx messages. Data model and serialization in most classes (not all)
    • Messenger implements the actual messaging protocol like "send back Reply To Discovery message in reply to Discovery Inquiry message"
    • ObservableProfileList and ObservablePropertyList hold profiles and properties (both values and metadata for now) that can notify listeners. Models in ktmidi-ci-tool make use of them.
    • MidiCIClientPropertyRules and MidiCIServicePropertyRules exist to decouple "Common Rules for PE" specific implementation from the core - ideally.
      • The actual Common Rules for PE implementation lies in dev.atsushieno.ktmidi.ci.propertycommonrules package.
      • Note that ktmidi-ci-tool is not intended to decouple the specs; it is strongly tied to the Common Rules. (In ktmidi-ci there are still some injection from the Common Rules.)
    • MidiMessageReporter provides end-user developers to handle MIDI Message Report results.
  • In ktmidi-ci-tool module:
    • dev.atsushieno.ktmidi.citool.view package contains @Composables.
    • CIToolRepository is supposed to work as the repository facade.
    • SavedSettings works as the serializable saved configuration. We use kotlinx.Serialization JSON to save the settings.

Platform support

The state of ktmidi-ci-tool platform support is complicated due to multiple premises:

Platform exists? virtual ports MIDI2 Compose
Windows-javax.sound.midi o - - o
Mac-rtmidi-javacpp o o - o
Mac-coremidi4j - o - o
Linux-alsakt o o WIP o
Windows-rtmidi (native) o o - -
Mac-rtmidi (native) o o - -
Mac-coremidi (native) CoreMidiAccess? o o -
Linux-rtmidi (native) o o - -
Linux-alsa (native) - o o -
Android o o o o
iOS-coremidi CoreMidiAccess? - o o