From 47761b1ad9fbf6eaca7faaa5fe2c8bbcbdcf4cd6 Mon Sep 17 00:00:00 2001 From: Tim Blechmann Date: Wed, 4 May 2005 11:56:46 +0000 Subject: initial checkin svn path=/trunk/externals/tb/; revision=2894 --- jack_transport/jack_transport.c | 116 +++++++++++++++++++++++++++++++++++++++ jack_transport/jack_transport.pd | 11 ++++ jack_transport/makefile | 94 +++++++++++++++++++++++++++++++ 3 files changed, 221 insertions(+) create mode 100644 jack_transport/jack_transport.c create mode 100644 jack_transport/jack_transport.pd create mode 100644 jack_transport/makefile (limited to 'jack_transport') diff --git a/jack_transport/jack_transport.c b/jack_transport/jack_transport.c new file mode 100644 index 0000000..053e75b --- /dev/null +++ b/jack_transport/jack_transport.c @@ -0,0 +1,116 @@ +/* +* +* jack_transport Copyright (C) 2005 Tim Blechmann +* +* This program is free software; you can redistribute it and/or modify +* it under the terms of the GNU General Public License as published by +* the Free Software Foundation; either version 2 of the License, or +* (at your option) any later version. +* +* This program is distributed in the hope that it will be useful, +* but WITHOUT ANY WARRANTY; without even the implied warranty of +* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +* GNU General Public License for more details. +* +* You should have received a copy of the GNU General Public License +* along with this program; see the file COPYING. If not, write to +* the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +* Boston, MA 02111-1307, USA. +*/ + +#include "m_pd.h" +#include "jack/jack.h" +#include "stdio.h" + +static t_class *jack_transport_class; + +typedef struct _jack_transport +{ + t_object x_obj; + t_outlet * x_outlet; + jack_client_t* x_jack_client; + jack_position_t* x_pos; +} jack_transport_t; + + +/* connect to jack server */ +static int jack_transport_connect(jack_transport_t * x) +{ + char port_name[80] = ""; + + static int client = 0; + do + { + sprintf(port_name,"pure_data_jack_transport_%d",client); + client++; + } + while (((x->x_jack_client = jack_client_new (port_name)) == 0) && + client < 100); + client = 0; + + if (!x->x_jack_client) + { + post("jack_transport: can't connect to jack server"); + return 1; + } + + post("jack_transport: connecting as %s", port_name); + + jack_activate(x->x_jack_client); + + return 0; +} + + +static jack_transport_t * jack_transport_new(void) +{ + int status = 0; + jack_transport_t *x = (jack_transport_t*) pd_new(jack_transport_class); + + x->x_outlet = outlet_new(&x->x_obj, NULL); + x->x_pos = (jack_position_t*) getbytes(sizeof(jack_position_t)); + + status = jack_transport_connect(x); + + return x; +} + +static void jack_transport_starter(jack_transport_t * x) +{ + jack_transport_start(x->x_jack_client); + return; +} + +static void jack_transport_stoper(jack_transport_t * x) +{ + jack_transport_stop(x->x_jack_client); + return; +} + +static void jack_transport_bang(jack_transport_t * x) +{ + float f; + if (!x->x_jack_client) + return; + + jack_transport_query(x->x_jack_client,x->x_pos); + + f = x->x_pos->frame; + + outlet_float(x->x_outlet, f); +} + + +void jack_transport_setup(void) +{ + jack_transport_class = class_new(gensym("jack_transport"), + (t_newmethod)jack_transport_new, + NULL, sizeof(jack_transport_t), + CLASS_DEFAULT, 0); + class_addmethod(jack_transport_class, (t_method)jack_transport_starter, + gensym("start"),0,0); + class_addmethod(jack_transport_class, (t_method)jack_transport_stoper, + gensym("stop"),0,0); + class_addbang(jack_transport_class, (t_method)jack_transport_bang); + +} diff --git a/jack_transport/jack_transport.pd b/jack_transport/jack_transport.pd new file mode 100644 index 0000000..e29286b --- /dev/null +++ b/jack_transport/jack_transport.pd @@ -0,0 +1,11 @@ +#N canvas 0 0 450 300 10; +#X floatatom 243 177 10 0 0 0 - - -; +#X obj 243 129 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +-1; +#X obj 243 153 jack_transport; +#X obj 243 203 / 48000; +#X floatatom 243 227 5 0 0 0 - - -; +#X connect 0 0 3 0; +#X connect 1 0 2 0; +#X connect 2 0 0 0; +#X connect 3 0 4 0; diff --git a/jack_transport/makefile b/jack_transport/makefile new file mode 100644 index 0000000..d4bb5fb --- /dev/null +++ b/jack_transport/makefile @@ -0,0 +1,94 @@ +NAME=jack_transport +CSYM=jack_transport + +current: pd_linux + +# ----------------------- NT ----------------------- + +pd_nt: $(NAME).dll + +.SUFFIXES: .dll + +PDNTCFLAGS = /W3 /WX /DNT /DPD /nologo +VC="C:\Program Files\Microsoft Visual Studio\Vc98" + +PDNTINCLUDE = /I. /I..\..\src /I$(VC)\include + +PDNTLDIR = $(VC)\lib +PDNTLIB = $(PDNTLDIR)\libc.lib \ + $(PDNTLDIR)\oldnames.lib \ + $(PDNTLDIR)\kernel32.lib \ + ..\..\bin\pd.lib + +.c.dll: + cl $(PDNTCFLAGS) $(PDNTINCLUDE) /c $*.c + link /dll /export:$(CSYM)_setup $*.obj $(PDNTLIB) + +# ----------------------- IRIX 5.x ----------------------- + +pd_irix5: $(NAME).pd_irix5 + +.SUFFIXES: .pd_irix5 + +SGICFLAGS5 = -o32 -DPD -DUNIX -DIRIX -O2 + +SGIINCLUDE = -I../../src + +.c.pd_irix5: + $(CC) $(SGICFLAGS5) $(SGIINCLUDE) -o $*.o -c $*.c + ld -elf -shared -rdata_shared -o $*.pd_irix5 $*.o + rm $*.o + +# ----------------------- IRIX 6.x ----------------------- + +pd_irix6: $(NAME).pd_irix6 + +.SUFFIXES: .pd_irix6 + +SGICFLAGS6 = -n32 -DPD -DUNIX -DIRIX -DN32 -woff 1080,1064,1185 \ + -OPT:roundoff=3 -OPT:IEEE_arithmetic=3 -OPT:cray_ivdep=true \ + -Ofast=ip32 + +.c.pd_irix6: + $(CC) $(SGICFLAGS6) $(SGIINCLUDE) -o $*.o -c $*.c + ld -n32 -IPA -shared -rdata_shared -o $*.pd_irix6 $*.o + rm $*.o + +# ----------------------- LINUX i386 ----------------------- + +pd_linux: $(NAME).pd_linux + +.SUFFIXES: .pd_linux + +LINUXCFLAGS = -DPD -O3 -fPIC -funroll-loops -fomit-frame-pointer \ + -Wall -W -Wshadow -Wstrict-prototypes -Werror \ + -Wno-unused -Wno-parentheses -Wno-switch -g + +LINUXINCLUDE = -I../../../src + +LSTRIP = strip --strip-unneeded -R .note -R .comment + +.c.pd_linux: + cc $(LINUXCFLAGS) $(LINUXINCLUDE) -o $*.o -c $*.c + cc -Wl,-export_dynamic --shared -o $*.pd_linux $*.o -lm + $(LSTRIP) $*.pd_linux + rm -f $*.o + +# ----------------------- Mac OSX ----------------------- + +pd_darwin: $(NAME).pd_darwin + +.SUFFIXES: .pd_darwin + +DARWINCFLAGS = -DPD -O2 -Wall -W -Wshadow -Wstrict-prototypes \ + -Wno-unused -Wno-parentheses -Wno-switch + +.c.pd_darwin: + $(CC) $(DARWINCFLAGS) $(LINUXINCLUDE) -o $*.o -c $*.c + $(CC) -bundle -undefined suppress -flat_namespace -o $*.pd_darwin $*.o + rm -f $*.o + +# ---------------------------------------------------------- + +clean: + rm -f *.o *.pd_* so_locations -- cgit v1.2.1 From ccfab7528a3acb2703eabb59e05b10de9a0026c8 Mon Sep 17 00:00:00 2001 From: Tim Blechmann Date: Thu, 5 May 2005 19:31:39 +0000 Subject: setting jack transport frame svn path=/trunk/externals/tb/; revision=2903 --- jack_transport/jack_transport.c | 13 ++++++++++--- jack_transport/jack_transport.pd | 18 ++++++++++-------- 2 files changed, 20 insertions(+), 11 deletions(-) (limited to 'jack_transport') diff --git a/jack_transport/jack_transport.c b/jack_transport/jack_transport.c index 053e75b..84b269e 100644 --- a/jack_transport/jack_transport.c +++ b/jack_transport/jack_transport.c @@ -92,14 +92,20 @@ static void jack_transport_bang(jack_transport_t * x) float f; if (!x->x_jack_client) return; - - jack_transport_query(x->x_jack_client,x->x_pos); - f = x->x_pos->frame; + f = (float)jack_get_current_transport_frame(x->x_jack_client); outlet_float(x->x_outlet, f); } +static void jack_transport_float(jack_transport_t * x, float f) +{ + if (!x->x_jack_client) + return; + + jack_transport_locate(x->x_jack_client, (jack_nframes_t)f); +} + void jack_transport_setup(void) { @@ -112,5 +118,6 @@ void jack_transport_setup(void) class_addmethod(jack_transport_class, (t_method)jack_transport_stoper, gensym("stop"),0,0); class_addbang(jack_transport_class, (t_method)jack_transport_bang); + class_addfloat(jack_transport_class, (t_method)jack_transport_float); } diff --git a/jack_transport/jack_transport.pd b/jack_transport/jack_transport.pd index e29286b..4460085 100644 --- a/jack_transport/jack_transport.pd +++ b/jack_transport/jack_transport.pd @@ -1,11 +1,13 @@ #N canvas 0 0 450 300 10; -#X floatatom 243 177 10 0 0 0 - - -; -#X obj 243 129 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +#X obj 100 141 jack_transport; +#X floatatom 140 118 5 0 0 0 - - -; +#X msg 191 120 stop; +#X msg 191 97 start; +#X floatatom 87 174 9 0 0 0 - - -; +#X obj 42 58 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; -#X obj 243 153 jack_transport; -#X obj 243 203 / 48000; -#X floatatom 243 227 5 0 0 0 - - -; -#X connect 0 0 3 0; -#X connect 1 0 2 0; +#X connect 0 0 4 0; +#X connect 1 0 0 0; #X connect 2 0 0 0; -#X connect 3 0 4 0; +#X connect 3 0 0 0; +#X connect 5 0 0 0; -- cgit v1.2.1 From e8c0887941bff7f23f48f8ccd5b8cab2c992a83f Mon Sep 17 00:00:00 2001 From: Hans-Christoph Steiner Date: Mon, 17 Dec 2007 06:23:46 +0000 Subject: changed helpfile to standard name svn path=/trunk/externals/tb/; revision=9097 --- jack_transport/jack_transport-help.pd | 13 +++++++++++++ jack_transport/jack_transport.pd | 13 ------------- jack_transport/makefile | 2 +- 3 files changed, 14 insertions(+), 14 deletions(-) create mode 100644 jack_transport/jack_transport-help.pd delete mode 100644 jack_transport/jack_transport.pd (limited to 'jack_transport') diff --git a/jack_transport/jack_transport-help.pd b/jack_transport/jack_transport-help.pd new file mode 100644 index 0000000..4460085 --- /dev/null +++ b/jack_transport/jack_transport-help.pd @@ -0,0 +1,13 @@ +#N canvas 0 0 450 300 10; +#X obj 100 141 jack_transport; +#X floatatom 140 118 5 0 0 0 - - -; +#X msg 191 120 stop; +#X msg 191 97 start; +#X floatatom 87 174 9 0 0 0 - - -; +#X obj 42 58 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 +-1; +#X connect 0 0 4 0; +#X connect 1 0 0 0; +#X connect 2 0 0 0; +#X connect 3 0 0 0; +#X connect 5 0 0 0; diff --git a/jack_transport/jack_transport.pd b/jack_transport/jack_transport.pd deleted file mode 100644 index 4460085..0000000 --- a/jack_transport/jack_transport.pd +++ /dev/null @@ -1,13 +0,0 @@ -#N canvas 0 0 450 300 10; -#X obj 100 141 jack_transport; -#X floatatom 140 118 5 0 0 0 - - -; -#X msg 191 120 stop; -#X msg 191 97 start; -#X floatatom 87 174 9 0 0 0 - - -; -#X obj 42 58 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 --1; -#X connect 0 0 4 0; -#X connect 1 0 0 0; -#X connect 2 0 0 0; -#X connect 3 0 0 0; -#X connect 5 0 0 0; diff --git a/jack_transport/makefile b/jack_transport/makefile index d4bb5fb..9446d42 100644 --- a/jack_transport/makefile +++ b/jack_transport/makefile @@ -64,7 +64,7 @@ LINUXCFLAGS = -DPD -O3 -fPIC -funroll-loops -fomit-frame-pointer \ -Wall -W -Wshadow -Wstrict-prototypes -Werror \ -Wno-unused -Wno-parentheses -Wno-switch -g -LINUXINCLUDE = -I../../../src +LINUXINCLUDE = -I../../../pd/src LSTRIP = strip --strip-unneeded -R .note -R .comment -- cgit v1.2.1 From 2c1ff19c4d99921dcd55176b5574e932dda39c68 Mon Sep 17 00:00:00 2001 From: Hans-Christoph Steiner Date: Tue, 9 Jun 2009 17:34:48 +0000 Subject: replaced -export_dynamic with --export-dynamic and -Wl,--export-dynamic where appropriate. It seems that once upon a time -export_dynamic was a real flag. Now it means -e xport_dynamic, meaning set the entry symbol to xport_dynamic, giving this error message: /usr/bin/ld: warning: cannot find entry symbol xport_dynamic; defaulting to 0000000000001b60 svn path=/trunk/externals/tb/; revision=11724 --- jack_transport/makefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'jack_transport') diff --git a/jack_transport/makefile b/jack_transport/makefile index 9446d42..5419c2c 100644 --- a/jack_transport/makefile +++ b/jack_transport/makefile @@ -70,7 +70,7 @@ LSTRIP = strip --strip-unneeded -R .note -R .comment .c.pd_linux: cc $(LINUXCFLAGS) $(LINUXINCLUDE) -o $*.o -c $*.c - cc -Wl,-export_dynamic --shared -o $*.pd_linux $*.o -lm + cc -Wl,--export-dynamic --shared -o $*.pd_linux $*.o -lm $(LSTRIP) $*.pd_linux rm -f $*.o -- cgit v1.2.1 From a95e3458aaa5f11f78006632be7b3f87d83febcd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?IOhannes=20m=20zm=C3=B6lnig?= Date: Thu, 30 Apr 2015 21:16:01 +0000 Subject: imported patch from Patrice Colet svn path=/trunk/externals/tb/; revision=17460 --- jack_transport/jack_transport.c | 34 ++++++++++++++++++++++++++++++---- 1 file changed, 30 insertions(+), 4 deletions(-) (limited to 'jack_transport') diff --git a/jack_transport/jack_transport.c b/jack_transport/jack_transport.c index 84b269e..e9efd11 100644 --- a/jack_transport/jack_transport.c +++ b/jack_transport/jack_transport.c @@ -24,27 +24,36 @@ static t_class *jack_transport_class; + +float time_beats_per_bar = 4.0; +float time_beat_type = 1.0 / 4.0; +double time_ticks_per_beat = 1920.0; +double time_beats_per_minute = 120.0; + typedef struct _jack_transport { t_object x_obj; t_outlet * x_outlet; + t_outlet * x_outlet_bar; + t_outlet * x_outlet_beat; + t_outlet * x_outlet_beat_type; + t_outlet * x_outlet_beats_per_bar; + t_outlet * x_outlet_beats_per_minute; jack_client_t* x_jack_client; jack_position_t* x_pos; } jack_transport_t; - /* connect to jack server */ static int jack_transport_connect(jack_transport_t * x) { char port_name[80] = ""; - static int client = 0; do { sprintf(port_name,"pure_data_jack_transport_%d",client); client++; } - while (((x->x_jack_client = jack_client_new (port_name)) == 0) && + while (((x->x_jack_client = jack_client_open (port_name, (jack_options_t)0, NULL)) == 0) && client < 100); client = 0; @@ -67,7 +76,13 @@ static jack_transport_t * jack_transport_new(void) int status = 0; jack_transport_t *x = (jack_transport_t*) pd_new(jack_transport_class); + x->x_outlet = outlet_new(&x->x_obj, NULL); + x->x_outlet_bar = outlet_new(&x->x_obj, NULL); + x->x_outlet_beat = outlet_new(&x->x_obj, NULL); + x->x_outlet_beat_type = outlet_new(&x->x_obj, NULL); + x->x_outlet_beats_per_bar = outlet_new(&x->x_obj, NULL); + x->x_outlet_beats_per_minute = outlet_new(&x->x_obj, NULL); x->x_pos = (jack_position_t*) getbytes(sizeof(jack_position_t)); status = jack_transport_connect(x); @@ -87,6 +102,17 @@ static void jack_transport_stoper(jack_transport_t * x) return; } +static void jack_transport_timebase(jack_transport_t * x) +{ + jack_position_t pos; + const int rolling = (jack_transport_query(x->x_jack_client, &pos) == JackTransportRolling); + outlet_float(x->x_outlet_bar, pos.bar); + outlet_float(x->x_outlet_beat, pos.beat); + outlet_float(x->x_outlet_beat_type, pos.beat_type); + outlet_float(x->x_outlet_beats_per_bar, pos.beats_per_bar); + outlet_float(x->x_outlet_beats_per_minute, pos.beats_per_minute); +} + static void jack_transport_bang(jack_transport_t * x) { float f; @@ -94,7 +120,7 @@ static void jack_transport_bang(jack_transport_t * x) return; f = (float)jack_get_current_transport_frame(x->x_jack_client); - + jack_transport_timebase(x); outlet_float(x->x_outlet, f); } -- cgit v1.2.1 From 622422f9fe647dc63fe9c80b1b7205a17e621586 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?IOhannes=20m=20zm=C3=B6lnig?= Date: Thu, 30 Apr 2015 21:38:10 +0000 Subject: collate extra outlets into a single one that emits routable messages svn path=/trunk/externals/tb/; revision=17461 --- jack_transport/jack_transport.c | 39 ++++++++++++++++++--------------------- 1 file changed, 18 insertions(+), 21 deletions(-) (limited to 'jack_transport') diff --git a/jack_transport/jack_transport.c b/jack_transport/jack_transport.c index e9efd11..f781346 100644 --- a/jack_transport/jack_transport.c +++ b/jack_transport/jack_transport.c @@ -25,20 +25,11 @@ static t_class *jack_transport_class; -float time_beats_per_bar = 4.0; -float time_beat_type = 1.0 / 4.0; -double time_ticks_per_beat = 1920.0; -double time_beats_per_minute = 120.0; - typedef struct _jack_transport { t_object x_obj; t_outlet * x_outlet; - t_outlet * x_outlet_bar; - t_outlet * x_outlet_beat; - t_outlet * x_outlet_beat_type; - t_outlet * x_outlet_beats_per_bar; - t_outlet * x_outlet_beats_per_minute; + t_outlet * x_outlet_info; jack_client_t* x_jack_client; jack_position_t* x_pos; } jack_transport_t; @@ -78,11 +69,7 @@ static jack_transport_t * jack_transport_new(void) x->x_outlet = outlet_new(&x->x_obj, NULL); - x->x_outlet_bar = outlet_new(&x->x_obj, NULL); - x->x_outlet_beat = outlet_new(&x->x_obj, NULL); - x->x_outlet_beat_type = outlet_new(&x->x_obj, NULL); - x->x_outlet_beats_per_bar = outlet_new(&x->x_obj, NULL); - x->x_outlet_beats_per_minute = outlet_new(&x->x_obj, NULL); + x->x_outlet_info = outlet_new(&x->x_obj, NULL); x->x_pos = (jack_position_t*) getbytes(sizeof(jack_position_t)); status = jack_transport_connect(x); @@ -105,12 +92,22 @@ static void jack_transport_stoper(jack_transport_t * x) static void jack_transport_timebase(jack_transport_t * x) { jack_position_t pos; + t_atom ap[8]; const int rolling = (jack_transport_query(x->x_jack_client, &pos) == JackTransportRolling); - outlet_float(x->x_outlet_bar, pos.bar); - outlet_float(x->x_outlet_beat, pos.beat); - outlet_float(x->x_outlet_beat_type, pos.beat_type); - outlet_float(x->x_outlet_beats_per_bar, pos.beats_per_bar); - outlet_float(x->x_outlet_beats_per_minute, pos.beats_per_minute); + SETFLOAT(ap+0, pos.bar); + SETFLOAT(ap+1, pos.beat); + SETSYMBOL(ap+2, gensym("type")); + SETFLOAT(ap+3, pos.beat_type); + SETSYMBOL(ap+4, gensym("beats/bar")); + SETFLOAT(ap+5, pos.beats_per_bar); + SETSYMBOL(ap+6, gensym("bpm")); + SETFLOAT(ap+7, pos.beats_per_minute); + + outlet_anything(x->x_outlet_info, gensym("beat"), 2, ap+2); + outlet_anything(x->x_outlet_info, gensym("beat"), 2, ap+4); + outlet_anything(x->x_outlet_info, gensym("beat"), 2, ap+6); + outlet_anything(x->x_outlet_info, gensym("beat"), 1, ap+1); + outlet_anything(x->x_outlet_info, gensym("bar"), 1, ap+0); } static void jack_transport_bang(jack_transport_t * x) @@ -139,7 +136,7 @@ void jack_transport_setup(void) (t_newmethod)jack_transport_new, NULL, sizeof(jack_transport_t), CLASS_DEFAULT, 0); - class_addmethod(jack_transport_class, (t_method)jack_transport_starter, + class_addmethod(jack_transport_class, (t_method)jack_transport_starter, gensym("start"),0,0); class_addmethod(jack_transport_class, (t_method)jack_transport_stoper, gensym("stop"),0,0); -- cgit v1.2.1 From 6932ee2d22511226378218992b0005cb01eb235e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?IOhannes=20m=20zm=C3=B6lnig?= Date: Thu, 30 Apr 2015 21:38:26 +0000 Subject: updated jack_transport help svn path=/trunk/externals/tb/; revision=17462 --- jack_transport/jack_transport-help.pd | 29 ++++++++++++++++++++++++----- 1 file changed, 24 insertions(+), 5 deletions(-) (limited to 'jack_transport') diff --git a/jack_transport/jack_transport-help.pd b/jack_transport/jack_transport-help.pd index 4460085..f244c5d 100644 --- a/jack_transport/jack_transport-help.pd +++ b/jack_transport/jack_transport-help.pd @@ -1,13 +1,32 @@ -#N canvas 0 0 450 300 10; +#N canvas 617 189 486 323 10; #X obj 100 141 jack_transport; -#X floatatom 140 118 5 0 0 0 - - -; +#X floatatom 140 118 5 0 0 0 - - -, f 5; #X msg 191 120 stop; #X msg 191 97 start; -#X floatatom 87 174 9 0 0 0 - - -; #X obj 42 58 bng 15 250 50 0 empty empty empty 0 -6 0 8 -262144 -1 -1; -#X connect 0 0 4 0; +#X obj 52 16 tgl 15 0 empty empty empty 17 7 0 10 -262144 -1 -1 1 1 +; +#X obj 190 178 route bar beat; +#X floatatom 237 223 0 0 0 0 - - -; +#X floatatom 288 243 0 0 0 0 - - -; +#X floatatom 340 263 0 0 0 0 - - -; +#X floatatom 392 283 0 0 0 0 - - -; +#X floatatom 156 233 0 0 0 0 - - -; +#X floatatom 100 173 0 0 0 0 - - -; +#X obj 237 201 route float type beats/bar bpm; +#X obj 43 35 metro 125; +#X connect 0 0 12 0; +#X connect 0 1 6 0; #X connect 1 0 0 0; #X connect 2 0 0 0; #X connect 3 0 0 0; -#X connect 5 0 0 0; +#X connect 4 0 0 0; +#X connect 5 0 14 0; +#X connect 6 0 11 0; +#X connect 6 1 13 0; +#X connect 13 0 7 0; +#X connect 13 1 8 0; +#X connect 13 2 9 0; +#X connect 13 3 10 0; +#X connect 14 0 4 0; -- cgit v1.2.1