diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/canvasconnections.c | 182 |
1 files changed, 144 insertions, 38 deletions
diff --git a/src/canvasconnections.c b/src/canvasconnections.c index 85e01e9..3c2bc90 100644 --- a/src/canvasconnections.c +++ b/src/canvasconnections.c @@ -109,9 +109,10 @@ static void intvec_post(t_intvec*vec) endpost(); } -static t_intvec**query_inletconnections(t_canvasconnections *x, int *num_inlets) { +static int query_inletconnections(t_canvasconnections *x, t_intvec***outobj, t_intvec***outwhich) { int i=0; t_intvec**invecs=NULL; + t_intvec**inwhich=NULL; int ninlets=0; int nin=0; @@ -121,8 +122,6 @@ static t_intvec**query_inletconnections(t_canvasconnections *x, int *num_inlets) return 0; ninlets=obj_ninlets(x->x_object); - *num_inlets=ninlets; - // TODO....find objects connecting TO this object /* as Pd does not have any information about connections to inlets, @@ -132,19 +131,24 @@ static t_intvec**query_inletconnections(t_canvasconnections *x, int *num_inlets) */ invecs=getbytes(sizeof(t_intvec*)*ninlets); - for(i=0; i<ninlets; i++)invecs[i]=intvec_new(0); + inwhich=getbytes(sizeof(t_intvec*)*ninlets); + for(i=0; i<ninlets; i++){ + invecs[i]=intvec_new(0); + inwhich[i]=intvec_new(0); + } for (y = x->x_parent->gl_list; y; y = y->g_next) /* traverse all objects in canvas */ { t_object*obj=(t_object*)y; int obj_nout=obj_noutlets(obj); int nout=0; + int sourcewhich=0; + for(nout=0; nout<obj_nout; nout++) { /* traverse all outlets of each object */ t_outlet*out=0; t_inlet *in =0; t_object*dest=0; - int sourcewhich=0; - + t_outconnect*conn=obj_starttraverseoutlet(obj, &out, nout); while(conn) { /* traverse all connections from each outlet */ @@ -157,39 +161,76 @@ static t_intvec**query_inletconnections(t_canvasconnections *x, int *num_inlets) /* add it to the inletconnectionlist */ intvec_add(invecs[which], connid); + intvec_add(inwhich[which], sourcewhich); } - sourcewhich++; } + sourcewhich++; + } } - return invecs; + if(outobj)*outobj=invecs; + if(outwhich)*outwhich=inwhich; + + // return invecs; + return ninlets; } static void canvasconnections_queryinlets(t_canvasconnections *x) { t_atom at; - int ninlets=0, i; - t_intvec**invecs=query_inletconnections(x, &ninlets); + t_intvec**invecs=0; + int ninlets=query_inletconnections(x, &invecs, 0); + int i; + // t_intvec**invecs=query_inletconnections(x, &ninlets); SETFLOAT(&at, (t_float)ninlets); outlet_anything(x->x_out, gensym("inlets"), 1, &at); for(i=0; i<ninlets; i++){ int size=invecs[i]->num_elements; + if(size>0) { + t_atom*ap=getbytes(sizeof(t_atom)*(size+1)); + int j=0; + SETFLOAT(ap, (t_float)i); + for(j=0; j<size; j++) + SETFLOAT(ap+j+1, ((t_float)invecs[i]->elements[j])); + + outlet_anything(x->x_out, gensym("inlet"), size+1, ap); + freebytes(ap, sizeof(t_atom)*(size+1)); + } + intvec_free(invecs[i]); + } + if(invecs)freebytes(invecs, sizeof(t_intvec*)*ninlets); +} + +static void canvasconnections_inlet(t_canvasconnections *x, t_floatarg f) +{ + int inlet=f; + t_atom at; + t_intvec**invecs=0; + int ninlets=query_inletconnections(x, &invecs, 0); + + if(inlet >= 0 && inlet < ninlets) { + int size=invecs[inlet]->num_elements; t_atom*ap=getbytes(sizeof(t_atom)*(size+1)); - int j=0; - SETFLOAT(ap, (t_float)i); - for(j=0; j<size; j++) - SETFLOAT(ap+j+1, ((t_float)invecs[i]->elements[j])); + SETFLOAT(ap, (t_float)inlet); + if(size>0) { + int j=0; + for(j=0; j<size; j++) + SETFLOAT(ap+j+1, ((t_float)invecs[inlet]->elements[j])); + } + outlet_anything(x->x_out, gensym("inlet"), size+1, ap); - - intvec_free(invecs[i]); freebytes(ap, sizeof(t_atom)*(size+1)); + + intvec_free(invecs[inlet]); } if(invecs)freebytes(invecs, sizeof(t_intvec*)*ninlets); } + + static int canvasconnections_inlets(t_canvasconnections *x) { t_atom at; @@ -208,20 +249,39 @@ static int canvasconnections_inlets(t_canvasconnections *x) return ninlets; } -static void canvasconnections_inlet(t_canvasconnections *x, t_floatarg f) +static void canvasconnections_inconnect(t_canvasconnections *x, t_floatarg f) { - int inlet=f; - t_atom at[4]; - int ninlets=0; + const int inlet=f; + t_intvec**invecs=0; + t_intvec**inwhich=0; - t_intvec**inlets=query_inletconnections(x, &ninlets); - if(!inlets || inlet < 0 || inlet>ninlets) { + int ninlets=query_inletconnections(x, &invecs, &inwhich); + if(!ninlets || inlet < 0 || inlet>ninlets) { + post("nonexisting inlet: %d", inlet); /* non-existing inlet! */ return; } else { - post("TODO"); + int i; + t_atom at[4]; + int id=glist_getindex(x->x_parent, (t_gobj*)x->x_object); + for(i=0; i<ninlets; i++){ + if(inlet==i) { + int j=0; + for(j=0; j<invecs[i]->num_elements; j++) { + SETFLOAT(at+0, (t_float)invecs[i]->elements[j]); + SETFLOAT(at+1, (t_float)inwhich[i]->elements[j]); + SETFLOAT(at+2, (t_float)id); + SETFLOAT(at+3, (t_float)i); + outlet_anything(x->x_out, gensym("inconnect"), 4, at); + } + } + intvec_free(invecs[i]); + intvec_free(inwhich[i]); + } } + if(invecs)freebytes(invecs, sizeof(t_intvec*)*ninlets); + if(inwhich)freebytes(inwhich, sizeof(t_intvec*)*ninlets); } @@ -240,7 +300,7 @@ static int canvasconnections_outlets(t_canvasconnections *x) return noutlets; } -static void canvasconnections_outlet(t_canvasconnections *x, t_floatarg f) +static void canvasconnections_outconnect(t_canvasconnections *x, t_floatarg f) { int outlet=f; t_atom at[4]; @@ -279,7 +339,49 @@ static void canvasconnections_outlet(t_canvasconnections *x, t_floatarg f) outlet_anything(x->x_out, gensym("outconnect"), 4, at); } } +} +static void canvasconnections_outlet(t_canvasconnections *x, t_floatarg f) +{ + int outlet=f; + t_atom*at=NULL; + int noutlets=0; + + if(0==x->x_object || 0==x->x_parent) + return; + + noutlets=obj_noutlets(x->x_object); + + if(outlet >= 0 && outlet < noutlets) { + t_outlet*out=0; + t_inlet*in=0; + t_object*dest=0; + int which; + t_outconnect*conn=obj_starttraverseoutlet(x->x_object, &out, outlet); + t_atom*abuf=0; + int count=0; + while(conn) { + conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); + count++; + } + abuf=(t_atom*)getbytes(sizeof(t_atom)*(count+1)); + SETFLOAT(abuf, outlet); + + if(count>0) { + int i=0; + conn=obj_starttraverseoutlet(x->x_object, &out, outlet); + while(conn) { + int connid=0; + conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); + connid = glist_getindex(x->x_parent, (t_gobj*)dest); + + SETFLOAT(abuf+1+i, (t_float)connid); + i++; + } + } + outlet_anything(x->x_out, gensym("outlet"), count+1, abuf); + freebytes(abuf, sizeof(t_atom)*(count+1)); + } } static void canvasconnections_queryoutlets(t_canvasconnections *x) @@ -293,25 +395,27 @@ static void canvasconnections_queryoutlets(t_canvasconnections *x) t_object*dest=0; t_inlet*in=0; int which=0; - int count=0, i=0; - t_atom*abuf=0; + int count=0; while(conn) { conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); count++; } - abuf=(t_atom*)getbytes(sizeof(t_atom)*(count+1)); - SETFLOAT(abuf, nout); - conn=obj_starttraverseoutlet(x->x_object, &out, nout); - while(conn) { - int connid=0; - conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); - connid = glist_getindex(x->x_parent, (t_gobj*)dest); - - SETFLOAT(abuf+1+i, (t_float)connid); - i++; + if(count>0) { + int i=0; + t_atom*abuf=(t_atom*)getbytes(sizeof(t_atom)*(count+1)); + SETFLOAT(abuf, nout); + conn=obj_starttraverseoutlet(x->x_object, &out, nout); + while(conn) { + int connid=0; + conn=obj_nexttraverseoutlet(conn, &dest, &in, &which); + connid = glist_getindex(x->x_parent, (t_gobj*)dest); + + SETFLOAT(abuf+1+i, (t_float)connid); + i++; + } + outlet_anything(x->x_out, gensym("outlet"), count+1, abuf); + freebytes(abuf, sizeof(t_atom)*(count+1)); } - outlet_anything(x->x_out, gensym("outlet"), count+1, abuf); - freebytes(abuf, sizeof(t_atom)*(count+1)); } } @@ -365,7 +469,9 @@ void canvasconnections_setup(void) class_addmethod(canvasconnections_class, (t_method)canvasconnections_outlets, gensym("outlets"), 0); class_addmethod(canvasconnections_class, (t_method)canvasconnections_outlet, gensym("outlet"), A_FLOAT, 0); + class_addmethod(canvasconnections_class, (t_method)canvasconnections_outconnect, gensym("outconnect"), A_FLOAT, 0); class_addmethod(canvasconnections_class, (t_method)canvasconnections_inlets, gensym("inlets"), 0); class_addmethod(canvasconnections_class, (t_method)canvasconnections_inlet, gensym("inlet"), A_FLOAT, 0); + class_addmethod(canvasconnections_class, (t_method)canvasconnections_inconnect, gensym("inconnect"), A_FLOAT, 0); } |