From 162fd02f2110b76d79ef1882625fa9778094e754 Mon Sep 17 00:00:00 2001 From: Albert Graef <aggraef@gmail.com> Date: Mon, 13 Feb 2017 11:30:29 +0100 Subject: [PATCH] Make sure that inmidi_clk() is called in the right place in the MIDI back-end. Fixes #255. --- pd/src/s_midi.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/pd/src/s_midi.c b/pd/src/s_midi.c index d1a20a003..50f5ed7e9 100644 --- a/pd/src/s_midi.c +++ b/pd/src/s_midi.c @@ -291,6 +291,7 @@ typedef struct midiparser /* functions in x_midi.c */ void inmidi_realtimein(int portno, int cmd); +void inmidi_clk(double timing); void inmidi_byte(int portno, int byte); void inmidi_sysex(int portno, int byte); void inmidi_noteon(int portno, int channel, int pitch, int velo); @@ -313,7 +314,17 @@ static void sys_dispatchnextmidiin( void) outlet_setstacklim(); if (byte >= 0xf8) + { inmidi_realtimein(portno, byte); + if (byte == 0xf8) { + // AG: Not sure what the timebase for the right outlet is supposed + // to be. I'm using msecs right now, which is in line with the other + // tempo-related objects such as metro. Uncomment the .001 factor to + // get seconds instead. + double timing = /*.001 * */clock_gettimesince(sys_midiinittime); + inmidi_clk(timing); + } + } else { inmidi_byte(portno, byte); -- GitLab