aboutsummaryrefslogtreecommitdiff
path: root/src/canvasconnection.c
diff options
context:
space:
mode:
authorIOhannes m zmölnig <zmoelnig@users.sourceforge.net>2008-07-23 11:41:40 +0000
committerIOhannes m zmölnig <zmoelnig@users.sourceforge.net>2008-07-23 11:41:40 +0000
commit375a3141c6153cf1f6a0e3102ea919c3d6292dd6 (patch)
treeeccd6a55eba2ea8bf28020d72718c11084f356dc /src/canvasconnection.c
parent925c6113a59ec5f139de2b663f57ecfc049142fc (diff)
renamed object
svn path=/trunk/externals/iem/iemguts/; revision=10211
Diffstat (limited to 'src/canvasconnection.c')
-rw-r--r--src/canvasconnection.c129
1 files changed, 0 insertions, 129 deletions
diff --git a/src/canvasconnection.c b/src/canvasconnection.c
deleted file mode 100644
index 58f881a..0000000
--- a/src/canvasconnection.c
+++ /dev/null
@@ -1,129 +0,0 @@
-
-/******************************************************
- *
- * canvasconnection - implementation file
- *
- * copyleft (c) IOhannes m zmölnig
- *
- * 2007:forum::für::umläute:2007
- *
- * institute of electronic music and acoustics (iem)
- *
- ******************************************************
- *
- * license: GNU General Public License v.2
- *
- ******************************************************/
-
-
-/*
- * this object provides a way to send messages to upstream canvases
- * by default it sends messages to the containing canvas, but you can give the
- * "depth" as argument;
- * e.g. [canvasconnection 1] will send messages to the parent of the containing canvas
- */
-
-#include "m_pd.h"
-#include "g_canvas.h"
-#include "m_imp.h"
-
-int glist_getindex(t_glist *x, t_gobj *y);
-
-/* ------------------------- canvasconnection ---------------------------- */
-
-static t_class *canvasconnection_class;
-
-typedef struct _canvasconnection
-{
- t_object x_obj;
- t_canvas *x_parent;
- t_object *x_object;
- t_outlet *x_out;
-} t_canvasconnection;
-
-static void canvasconnection_outlets(t_canvasconnection *x)
-{
- int noutlets=0;
- int nout=0;
- t_atom at;
-
- if(0==x->x_object || 0==x->x_parent)
- return;
-
- noutlets=obj_noutlets(x->x_object);
- SETFLOAT(&at, (t_float)noutlets);
-
- outlet_anything(x->x_out, gensym("outlets"), 1, &at);
- for(nout=0; nout<noutlets; nout++) {
- t_outlet*out=0;
- t_outconnect*conn=obj_starttraverseoutlet(x->x_object, &out, nout);
- t_object*dest=0;
- t_inlet*in=0;
- int which=0;
- int count=0, i=0;
- t_atom*abuf=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) {
- t_float connid=0;
- conn=obj_nexttraverseoutlet(conn, &dest, &in, &which);
- connid = glist_getindex(x->x_parent, (t_gobj*)dest);
- SETFLOAT(abuf+1+i, connid);
- i++;
- }
- outlet_anything(x->x_out, gensym("outlet"), count+1, abuf);
- freebytes(abuf, sizeof(t_atom)*(count+1));
- }
-}
-
-static void canvasconnection_bang(t_canvasconnection *x)
-{
- canvasconnection_outlets(x);
-}
-
-
-static void canvasconnection_free(t_canvasconnection *x)
-{
- x->x_object=0;
- outlet_free(x->x_out);
- x->x_out=0;
-}
-
-static void *canvasconnection_new(t_floatarg f)
-{
- t_canvasconnection *x = (t_canvasconnection *)pd_new(canvasconnection_class);
- t_glist *glist=(t_glist *)canvas_getcurrent();
- t_canvas *canvas=(t_canvas*)glist_getcanvas(glist);
- int depth=(int)f;
- if(depth<0)depth=0;
-
- x->x_parent=0;
- x->x_object=0;
-
- while(depth && canvas) {
- canvas=canvas->gl_owner;
- depth--;
- }
-
-
- if(canvas) {
- x->x_object = pd_checkobject((t_pd*)canvas);
- x->x_parent = canvas->gl_owner;
- }
-
- x->x_out=outlet_new(&x->x_obj, 0);
-
- return (x);
-}
-
-void canvasconnection_setup(void)
-{
- canvasconnection_class = class_new(gensym("canvasconnection"), (t_newmethod)canvasconnection_new,
- (t_method)canvasconnection_free, sizeof(t_canvasconnection), 0, A_DEFFLOAT, 0);
- class_addbang(canvasconnection_class, (t_method)canvasconnection_bang);
-}