From 31b83223fc2e9f03c8aa89765e090a391947b7e6 Mon Sep 17 00:00:00 2001 From: Christopher Arndt Date: Tue, 23 May 2023 01:26:50 +0200 Subject: [PATCH] feat: add MIDI receiver example showing use of threads/channels Signed-off-by: Christopher Arndt --- examples/jacket_midi_print_thread.nim | 125 ++++++++++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 examples/jacket_midi_print_thread.nim diff --git a/examples/jacket_midi_print_thread.nim b/examples/jacket_midi_print_thread.nim new file mode 100644 index 0000000..c803556 --- /dev/null +++ b/examples/jacket_midi_print_thread.nim @@ -0,0 +1,125 @@ +import std/[logging, os, strutils] +import signal +import jacket + +var + jclient: ClientP + event: MidiEvent + midiPort: PortP + midiEventChan: Channel[MidiEvent] + midiEventPrinter: Thread[void] + status: cint + exitSignalled: bool = false + +var log = newConsoleLogger(when defined(release): lvlInfo else: lvlDebug) + + +proc cleanup() = + debug "Cleaning up..." + + if jclient != nil: + debug "Deactivating JACK client..." + discard jclient.deactivate() + + if midiEventPrinter.running: + debug "Stopping MIDI event printer thread..." + # Receiving an invalid event causes receiving thread to wake up and + # break its endless loop + event.size = 0 + midiEventChan.send(event) + + midiEventPrinter.joinThread() + + debug "Closing MIDI event channel..." + midiEventChan.close() + + if jclient != nil: + debug "Closing JACK client..." + discard jclient.clientClose() + jclient = nil + + debug "Bye." + +proc errorCb(msg: cstring) {.cdecl.} = + # Suppress verbose JACK error messages when server is not available by + # default. Pass ``lvlAll`` when creating the logger to enable them. + debug "JACK error: " & $msg + +proc signalCb(sig: cint) {.noconv.} = + info "Received signal: " & $sig + exitSignalled = true + +proc shutdownCb(arg: pointer = nil) {.cdecl.} = + info "JACK server has shut down." + exitSignalled = true + +proc midiEventPrinterProc() = + var event: MidiEvent + + while true: + event = midiEventChan.recv() + + if event.size == 0: + break + elif event.size <= 3: + for i in 0..