aboutsummaryrefslogtreecommitdiff
path: root/pmpd2d_get.c
diff options
context:
space:
mode:
authorCyrille Henry <nusmuk@users.sourceforge.net>2013-04-08 22:57:39 +0000
committerCyrille Henry <nusmuk@users.sourceforge.net>2013-04-08 22:57:39 +0000
commitae5c64be35653c67533176657bdb16f471fcf50f (patch)
treec1b3c04939698b1866e486f2185f5cd47989e8d0 /pmpd2d_get.c
parentcdc1e62f0dd1a08648fc5e7bd6a9b5138a036681 (diff)
code refactorisation, and few new fonctionalities copied from pmpd3d
svn path=/trunk/externals/pmpd/; revision=17073
Diffstat (limited to 'pmpd2d_get.c')
-rw-r--r--pmpd2d_get.c554
1 files changed, 554 insertions, 0 deletions
diff --git a/pmpd2d_get.c b/pmpd2d_get.c
new file mode 100644
index 0000000..8483d23
--- /dev/null
+++ b/pmpd2d_get.c
@@ -0,0 +1,554 @@
+void pmpd2d_get(t_pmpd2d *x, t_symbol *s, int argc, t_atom *argv)
+{
+ int i;
+ t_symbol *toget;
+ t_atom toout[5];
+ toget = atom_getsymbolarg(0, argc, argv);
+
+ if ( (toget == gensym("massesPos")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].posX);
+ SETFLOAT(&(toout[2]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massesPosNo"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesPos")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->mass[i].Id)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].posX);
+ SETFLOAT(&(toout[2]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massesPosId"), 3, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("massesPos")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].posX);
+ SETFLOAT(&(toout[2]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massesPos"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesPosName")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].posX);
+ SETFLOAT(&(toout[2]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massesPosNameNo"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesPosName")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->mass[i].Id)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].posX);
+ SETFLOAT(&(toout[2]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massesPosNameId"), 3, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("massesPosName")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].posX);
+ SETFLOAT(&(toout[2]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massesPosName"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesSpeeds")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].speedX);
+ SETFLOAT(&(toout[2]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massesSpeedsNo"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesSpeeds")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->mass[i].Id)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].speedX);
+ SETFLOAT(&(toout[2]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massesSpeedsId"), 3, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("massesSpeeds")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].speedX);
+ SETFLOAT(&(toout[2]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massesSpeeds"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesSpeedsName")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].speedX);
+ SETFLOAT(&(toout[2]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massesSpeedsNameNo"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesSpeedsName")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->mass[i].Id)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].speedX);
+ SETFLOAT(&(toout[2]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massesSpeedsNameId"), 3, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("massesSpeedsName")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].speedX);
+ SETFLOAT(&(toout[2]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massesSpeedsName"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesForces")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].forceX);
+ SETFLOAT(&(toout[2]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massesForcesNo"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesForces")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->mass[i].Id)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].forceX);
+ SETFLOAT(&(toout[2]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massesForcesId"), 3, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("massesForces")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->mass[i].forceX);
+ SETFLOAT(&(toout[2]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massesForces"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesForcesName")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].forceX);
+ SETFLOAT(&(toout[2]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massesForcesNameNo"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("massesForcesName")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->mass[i].Id)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].forceX);
+ SETFLOAT(&(toout[2]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massesForcesNameId"), 3, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("massesForcesName")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), x->mass[i].forceX);
+ SETFLOAT(&(toout[2]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massesForcesName"), 3, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("linksPos")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[3]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[4]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linksPosNo"), 5, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("linksPos")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_link; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->link[i].Id)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[3]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[4]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linksPosNo"), 5, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("linksPos")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_link; i++)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[3]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[4]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linksPosNo"), 5, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("linksPosName")) && (argv[1].a_type == A_FLOAT) )
+ {
+ i = atom_getfloatarg(1, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[3]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[4]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linksPosNo"), 5, toout);
+ }
+ }
+ else
+ if ( (toget == gensym("linksPosName")) && (argv[1].a_type == A_SYMBOL) )
+ {
+ for (i=0; i< x->nb_link; i++)
+ {
+ if ( atom_getsymbolarg(1,argc,argv) == x->link[i].Id)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[3]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[4]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linksPosNo"), 5, toout);
+ }
+ }
+ }
+ else
+ if ( (toget == gensym("linksPosName")) && (argc == 1) )
+ {
+ for (i=0; i< x->nb_link; i++)
+ {
+ SETFLOAT(&(toout[0]), i);
+ SETFLOAT(&(toout[1]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[3]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[4]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linksPosNo"), 5, toout);
+ }
+ }
+ else
+ error("not get attribute");
+}
+
+void pmpd2d_massPos(t_pmpd2d *x, t_symbol *s, int argc, t_atom *argv)
+{
+ int i;
+ t_atom toout[4];
+
+ if ((argc>0)&&(argv[0].a_type == A_FLOAT))
+ {
+ i = atom_getfloatarg(0, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].posX);
+ SETFLOAT(&(toout[3]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massPos"), 4, toout);
+ }
+ }
+ else
+ if ((argc>0)&&(argv[0].a_type == A_SYMBOL))
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), atom_getsymbolarg(0,argc,argv));
+ if ( atom_getsymbolarg(0,argc,argv) == x->mass[i].Id)
+ {
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].posX);
+ SETFLOAT(&(toout[3]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massPos"), 4, toout);
+ }
+ }
+ }
+ else
+ if (argc == 0)
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].posX);
+ SETFLOAT(&(toout[3]), x->mass[i].posY);
+ outlet_anything(x->main_outlet, gensym("massPos"), 4, toout);
+ }
+ }
+}
+
+void pmpd2d_massSpeed(t_pmpd2d *x, t_symbol *s, int argc, t_atom *argv)
+{
+ int i;
+ t_atom toout[4];
+
+ if ((argc>0)&&(argv[0].a_type == A_FLOAT))
+ {
+ i = atom_getfloatarg(0, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].speedX);
+ SETFLOAT(&(toout[3]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massSpeed"), 4, toout);
+ }
+ }
+ else
+ if ((argc>0)&&(argv[0].a_type == A_SYMBOL))
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), atom_getsymbolarg(0,argc,argv));
+ if ( atom_getsymbolarg(0,argc,argv) == x->mass[i].Id)
+ {
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].speedX);
+ SETFLOAT(&(toout[3]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massSpeed"), 4, toout);
+ }
+ }
+ }
+ else
+ if (argc == 0)
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].speedX);
+ SETFLOAT(&(toout[3]), x->mass[i].speedY);
+ outlet_anything(x->main_outlet, gensym("massSpeed"), 4, toout);
+ }
+ }
+}
+
+void pmpd2d_massForce(t_pmpd2d *x, t_symbol *s, int argc, t_atom *argv)
+{
+ int i;
+ t_atom toout[4];
+
+ if ((argc>0)&&(argv[0].a_type == A_FLOAT))
+ {
+ i = atom_getfloatarg(0, argc, argv);
+ if ( (i>=0) && (i<x->nb_mass) )
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].forceX);
+ SETFLOAT(&(toout[3]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massForce"), 4, toout);
+ }
+ }
+ else
+ if ((argc>0)&&(argv[0].a_type == A_SYMBOL))
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), atom_getsymbolarg(0,argc,argv));
+ if ( atom_getsymbolarg(0,argc,argv) == x->mass[i].Id)
+ {
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].forceX);
+ SETFLOAT(&(toout[3]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massForce"), 4, toout);
+ }
+ }
+ }
+ else
+ if (argc == 0)
+ {
+ for (i=0; i< x->nb_mass; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->mass[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->mass[i].forceX);
+ SETFLOAT(&(toout[3]), x->mass[i].forceY);
+ outlet_anything(x->main_outlet, gensym("massForce"), 4, toout);
+ }
+ }
+}
+
+void pmpd2d_linkEnd(t_pmpd2d *x, t_symbol *s, int argc, t_atom *argv)
+{
+ int i;
+ t_atom toout[6];
+
+ if ((argc>0)&&(argv[0].a_type == A_FLOAT))
+ {
+ i = atom_getfloatarg(0, argc, argv);
+ if ( (i>=0) && (i<x->nb_link) )
+ {
+ SETSYMBOL(&(toout[0]), x->link[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[3]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[5]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[6]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linkEnd"), 6, toout);
+ }
+ }
+ else
+ if ((argc>0)&&(argv[0].a_type == A_SYMBOL))
+ {
+ SETSYMBOL(&(toout[0]), atom_getsymbolarg(0,argc,argv));
+ for (i=0; i< x->nb_link; i++)
+ {
+ if ( atom_getsymbolarg(0,argc,argv) == x->link[i].Id)
+ {
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[3]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[5]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[6]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linkEnd"), 6, toout);
+ }
+ }
+ }
+ else
+ if (argc == 0)
+ {
+ for (i=0; i< x->nb_link; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->link[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), x->link[i].mass1->posX);
+ SETFLOAT(&(toout[3]), x->link[i].mass1->posY);
+ SETFLOAT(&(toout[5]), x->link[i].mass2->posX);
+ SETFLOAT(&(toout[6]), x->link[i].mass2->posY);
+ outlet_anything(x->main_outlet, gensym("linkEnd"), 6, toout);
+ }
+ }
+}
+
+void pmpd2d_linkPos(t_pmpd2d *x, t_symbol *s, int argc, t_atom *argv)
+{
+ int i;
+ t_atom toout[4];
+
+ if ((argc>0)&&(argv[0].a_type == A_FLOAT))
+ {
+ i = atom_getfloatarg(0, argc, argv);
+ if ( (i>=0) && (i<x->nb_link) )
+ {
+ SETSYMBOL(&(toout[0]), x->link[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), (x->link[i].mass1->posX+x->link[i].mass2->posX)/2);
+ SETFLOAT(&(toout[3]), (x->link[i].mass1->posY+x->link[i].mass2->posY)/2);
+ outlet_anything(x->main_outlet, gensym("linkPos"), 4, toout);
+ }
+ }
+ else
+ if ((argc>0)&&(argv[0].a_type == A_SYMBOL))
+ {
+ SETSYMBOL(&(toout[0]), atom_getsymbolarg(0,argc,argv));
+ for (i=0; i< x->nb_link; i++)
+ {
+ if ( atom_getsymbolarg(0,argc,argv) == x->link[i].Id)
+ {
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), (x->link[i].mass1->posX+x->link[i].mass2->posX)/2);
+ SETFLOAT(&(toout[3]), (x->link[i].mass1->posY+x->link[i].mass2->posY)/2);
+ outlet_anything(x->main_outlet, gensym("linkPos"), 4, toout);
+ }
+ }
+ }
+ else
+ if (argc == 0)
+ {
+ for (i=0; i< x->nb_link; i++)
+ {
+ SETSYMBOL(&(toout[0]), x->link[i].Id);
+ SETFLOAT(&(toout[1]), i);
+ SETFLOAT(&(toout[2]), (x->link[i].mass1->posX+x->link[i].mass2->posX)/2);
+ SETFLOAT(&(toout[3]), (x->link[i].mass1->posY+x->link[i].mass2->posY)/2);
+ outlet_anything(x->main_outlet, gensym("linkPos"), 4, toout);
+ }
+ }
+}
+