diff options
-rw-r--r-- | iemlib1/src/for++.c | 187 |
1 files changed, 97 insertions, 90 deletions
diff --git a/iemlib1/src/for++.c b/iemlib1/src/for++.c index 76daecc..49bf1bb 100644 --- a/iemlib1/src/for++.c +++ b/iemlib1/src/for++.c @@ -1,88 +1,86 @@ /* For information on usage and redistribution, and for a DISCLAIMER OF ALL * WARRANTIES, see the file, "LICENSE.txt," in this distribution. -iemlib1 written by Thomas Musil, Copyright (c) IEM KUG Graz Austria 2000 - 2006 */ +iemlib1 written by Thomas Musil, Copyright (c) IEM KUG Graz Austria 2000 - 2011 */ #include "m_pd.h" #include "iemlib.h" -/* ----------------------------- for++ -------------------------------- */ -/* -- an internal timed counter (start-, stop-number and metro-time) -- */ +/* ------------------------------------ for++ -------------------------------------- */ +/* -- an optional timed counter (begin number, end number, metro time, increment) -- */ typedef struct _forpp { t_object x_obj; - int x_beg; - int x_end; - t_float x_delay; - int x_cur; - int x_incr; - void *x_out_end; - void *x_clock; - void *x_clock2; + double x_beg; + double x_end; + double x_delay; + double x_cur; + double x_incr; + t_outlet *x_out_counter; + t_outlet *x_out_end; + t_clock *x_clock_incr; + t_clock *x_clock_end; } t_forpp; static t_class *forpp_class; -static void forpp_tick2(t_forpp *x) +static void forpp_tick_end(t_forpp *x) { outlet_bang(x->x_out_end); - clock_unset(x->x_clock2); + clock_unset(x->x_clock_end); } -static void forpp_tick(t_forpp *x) +static void forpp_tick_incr(t_forpp *x) { - outlet_float(x->x_obj.ob_outlet, x->x_cur); + int stop_it=1; + + outlet_float(x->x_out_counter, (t_float)x->x_cur); x->x_cur += x->x_incr; if(x->x_incr > 0) { if(x->x_cur <= x->x_end) - clock_delay(x->x_clock, x->x_delay); - else - { - clock_unset(x->x_clock); - clock_delay(x->x_clock2, x->x_delay); - } + stop_it = 0; } else { if(x->x_cur >= x->x_end) - clock_delay(x->x_clock, x->x_delay); - else - { - clock_unset(x->x_clock); - clock_delay(x->x_clock2, x->x_delay); - } + stop_it = 0; } + + if(stop_it) + { + clock_unset(x->x_clock_incr); + clock_delay(x->x_clock_end, x->x_delay); + } + else + clock_delay(x->x_clock_incr, x->x_delay); } static void forpp_bang(t_forpp *x) { - x->x_cur = x->x_beg; - outlet_float(x->x_obj.ob_outlet, x->x_cur); - x->x_cur += x->x_incr; - if(x->x_incr > 0) + if(x->x_delay > 0.0) { - if(x->x_cur <= x->x_end) - clock_delay(x->x_clock, x->x_delay); - else - { - clock_unset(x->x_clock); - clock_delay(x->x_clock2, x->x_delay); - } + x->x_cur = x->x_beg; + forpp_tick_incr(x); } else { - if(x->x_cur >= x->x_end) - clock_delay(x->x_clock, x->x_delay); + double cur=x->x_beg, end=x->x_end, incr=x->x_incr; + + if(x->x_end < x->x_beg) + { + for(; cur >= end; cur += incr) + outlet_float(x->x_out_counter, (t_float)cur); + } else { - clock_unset(x->x_clock); - clock_delay(x->x_clock2, x->x_delay); + for(; cur <= end; cur += incr) + outlet_float(x->x_out_counter, (t_float)cur); } + outlet_bang(x->x_out_end); } - } static void forpp_start(t_forpp *x) @@ -92,90 +90,99 @@ static void forpp_start(t_forpp *x) static void forpp_stop(t_forpp *x) { - if(x->x_incr > 0) - x->x_cur = x->x_end + 1; - else - x->x_cur = x->x_end - 1; - clock_unset(x->x_clock); - clock_unset(x->x_clock2); + x->x_cur = x->x_end + x->x_incr; + clock_unset(x->x_clock_incr); + clock_unset(x->x_clock_end); } -static void forpp_float(t_forpp *x, t_floatarg beg) +static void forpp_ft3(t_forpp *x, t_floatarg incr) { - x->x_beg = (int)beg; if(x->x_end < x->x_beg) - x->x_incr = -1; + { + if(incr > 0.0) + incr = -incr; + } else - x->x_incr = 1; + { + if(incr < 0.0) + incr = -incr; + } + x->x_incr = (double)incr; +} + +static void forpp_ft2(t_forpp *x, t_floatarg delay) +{ + if(delay < 0.0) + delay = 0.0; + x->x_delay = (double)delay; } static void forpp_ft1(t_forpp *x, t_floatarg end) { - x->x_end = (int)end; - if(x->x_end < x->x_beg) - x->x_incr = -1; - else - x->x_incr = 1; + x->x_end = (double)end; + forpp_ft3(x, (t_floatarg)x->x_incr); } -static void forpp_ft2(t_forpp *x, t_floatarg delay) +static void forpp_float(t_forpp *x, t_floatarg beg) { - if(delay < 0.0) - delay = 0.0; - x->x_delay = delay; + x->x_beg = (double)beg; + forpp_ft3(x, (t_floatarg)x->x_incr); } static void forpp_list(t_forpp *x, t_symbol *s, int argc, t_atom *argv) { - if(argc == 2) - { - forpp_float(x, atom_getfloatarg(0, argc, argv)); + if((argc >= 4) && IS_A_FLOAT(argv, 3)) + forpp_ft3(x, atom_getfloatarg(3, argc, argv)); + if((argc >= 3) && IS_A_FLOAT(argv, 2)) + forpp_ft2(x, atom_getfloatarg(2, argc, argv)); + if((argc >= 2) && IS_A_FLOAT(argv, 1)) forpp_ft1(x, atom_getfloatarg(1, argc, argv)); - } - else if(argc == 3) - { + if((argc >= 1) && IS_A_FLOAT(argv, 0)) forpp_float(x, atom_getfloatarg(0, argc, argv)); - forpp_ft1(x, atom_getfloatarg(1, argc, argv)); - forpp_ft2(x, atom_getfloatarg(2, argc, argv)); - } } -static void *forpp_new(t_floatarg beg, t_floatarg end, t_floatarg delay) +static void *forpp_new(t_symbol *s, int argc, t_atom *argv) { t_forpp *x = (t_forpp *)pd_new(forpp_class); + t_float fbeg=0.0, fend=0.0, fdelay=0.0, fincr=1.0; // default + + if((argc >= 1) && IS_A_FLOAT(argv, 0)) + fbeg = (t_float)atom_getfloatarg(0, argc, argv); + if((argc >= 2) && IS_A_FLOAT(argv, 1)) + fend = (t_float)atom_getfloatarg(1, argc, argv); + if((argc >= 3) && IS_A_FLOAT(argv, 2)) + fdelay = (t_float)atom_getfloatarg(2, argc, argv); + if((argc >= 4) && IS_A_FLOAT(argv, 3)) + fincr = (t_float)atom_getfloatarg(3, argc, argv); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("ft1")); inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("ft2")); - outlet_new(&x->x_obj, &s_float); + inlet_new(&x->x_obj, &x->x_obj.ob_pd, &s_float, gensym("ft3")); + x->x_out_counter = outlet_new(&x->x_obj, &s_float); x->x_out_end = outlet_new(&x->x_obj, &s_bang); - x->x_clock = clock_new(x, (t_method)forpp_tick); - x->x_clock2 = clock_new(x, (t_method)forpp_tick2); - x->x_beg = (int)beg; - x->x_end = (int)end; - if(x->x_end < x->x_beg) - x->x_incr = -1; - else - x->x_incr = 1; - if(delay < 0.0) - delay = 0.0; - x->x_delay = delay; + x->x_clock_incr = clock_new(x, (t_method)forpp_tick_incr); + x->x_clock_end = clock_new(x, (t_method)forpp_tick_end); + + x->x_beg = (double)fbeg; + x->x_end = (double)fend; + forpp_ft3(x, (t_floatarg)fincr); + forpp_ft2(x, (t_floatarg)fdelay); x->x_cur = x->x_beg; return(x); } static void forpp_ff(t_forpp *x) { - clock_free(x->x_clock); - clock_free(x->x_clock2); + clock_free(x->x_clock_incr); + clock_free(x->x_clock_end); } void forpp_setup(void) { forpp_class = class_new(gensym("for++"), (t_newmethod)forpp_new, (t_method)forpp_ff, sizeof(t_forpp), - 0, A_DEFFLOAT, A_DEFFLOAT, A_DEFFLOAT, 0); - class_addcreator((t_newmethod)forpp_new, gensym("for_pp"), A_DEFFLOAT, A_DEFFLOAT, A_DEFFLOAT, 0); - + 0, A_GIMME, 0); + class_addcreator((t_newmethod)forpp_new, gensym("for_pp"), A_GIMME, 0); class_addbang(forpp_class, forpp_bang); class_addfloat(forpp_class, forpp_float); class_addlist(forpp_class, forpp_list); @@ -183,5 +190,5 @@ void forpp_setup(void) class_addmethod(forpp_class, (t_method)forpp_stop, gensym("stop"), 0); class_addmethod(forpp_class, (t_method)forpp_ft1, gensym("ft1"), A_FLOAT, 0); class_addmethod(forpp_class, (t_method)forpp_ft2, gensym("ft2"), A_FLOAT, 0); -// class_sethelpsymbol(forpp_class, gensym("iemhelp/help-for++")); + class_addmethod(forpp_class, (t_method)forpp_ft3, gensym("ft3"), A_FLOAT, 0); } |