aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorIOhannes m zmölnig <zmoelnig@users.sourceforge.net>2011-09-21 08:49:22 +0000
committerIOhannes m zmölnig <zmoelnig@users.sourceforge.net>2011-09-21 08:49:22 +0000
commite8479343f6a6db1d28e362469dfafaccca378421 (patch)
tree1f3e175a64a53c17e98b82b9ecc26ba5468b5473 /src
parent4ef4a3097fbdf5f0a13d3f5b3e60cdbb02fe1671 (diff)
allow anythings for pack/unpack
svn path=/trunk/externals/zexy/; revision=15326
Diffstat (limited to 'src')
-rw-r--r--src/pack.c89
-rw-r--r--src/unpack.c56
2 files changed, 99 insertions, 46 deletions
diff --git a/src/pack.c b/src/pack.c
index 7dd7f17..8980010 100644
--- a/src/pack.c
+++ b/src/pack.c
@@ -1,30 +1,34 @@
-
-/* 1903:forum::für::umläute:2005 */
-
-/*
- * mulitplex : zpack a specified input to the output
+/*
+ * pack: a type-agnostic version of [pack]
*
- * THINK: should the selector-inlet be the first or the last ???
- * pros/cons:
- * the 1st inlet being the selector is not consistant with pd (hot/cold)
- * but as it since the hot inlet is selectable, the whole object is not really consitant
- * numbering would have to start with 1 (for the 1st not-leftmost inlet)
- * if the selector is rightmost this would mean: cold is right(most), hot is (somewhere) left
- * numbering would be ok
+ * (c) 2007-2011 forum::für::umläute
*
- * conclusio: make the selector rightmost
+ * 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. If not, see <http://www.gnu.org/licenses/>.
+/*
+
+/*
+ * this version of [pack] does not care about types, so you can send a symbol to a float inlet and vice versa
+ * you can also initialize it with symbols, e.g. [pack foo bar] will output [list foo bar( when banged
*
+ * for know this object is named [zexy/pack], as there might be some issues with compatibility with the original [pack]
*/
#include "zexy.h"
#include <stdio.h>
-/* ------------------------- zpack ------------------------------- */
-
-/*
- a zpacker
-*/
+/* ------------------------- zexy/pack ------------------------------- */
static t_class *zpack_class;
static t_class *zpackproxy_class;
@@ -58,18 +62,46 @@ static void zpack_bang(t_zpack*x) {
outlet_list(x->x_obj.ob_outlet, gensym("list"), x->x_argc, x->x_argv);
}
-static void zpack_list0(t_zpack*x, t_symbol *s, int argc, t_atom *argv) {
+
+static void zpack_any(t_zpack*x, t_symbol *s, int argc, t_atom *argv) {
int i=0;
- for(i=0; i<argc && i<x->x_argc; i++)
- setatom(x, argv+i, i);
- zpack_bang(x);
+ int count=x->x_argc;
+
+ if(NULL!=s && x->x_argc>0) {
+ t_atom a;
+ SETSYMBOL(&a, s);
+ setatom(x, &a, i++);
+ count--;
+ }
+
+ if(count>argc)
+ count=argc;
+
+ while(count-->0) {
+ setatom(x, argv++, i++);
+ }
+
+ zpack_bang(x);
+}
+
+static void zpack_list(t_zpack*x, t_symbol *s, int argc, t_atom *argv) {
+ zpack_any(x, 0, argc, argv);
}
-static void zpack_list(t_zpackproxy *y, t_symbol *s, int argc, t_atom *argv)
+
+static void zpack_proxy_list(t_zpackproxy *y, t_symbol *s, int argc, t_atom *argv)
{
- if(argc>0)
+ /* until we have lists of lists, this only uses the 1st element */
+ if(argc>0) /* this filters out 'bang', and allows 'list', 'float' and 'symbol' */
setatom(y->p_master, argv, y->id);
}
+static void zpack_proxy_any(t_zpackproxy *y, t_symbol *s, int argc, t_atom *argv)
+{
+ /* until we have lists of lists, this only uses the selector */
+ t_atom a;
+ SETSYMBOL(&a, s);
+ setatom(y->p_master, &a, y->id);
+}
static void *zpack_new(t_symbol *s, int argc, t_atom *argv)
{
@@ -135,18 +167,19 @@ void zpack_setup(void)
zpack_class = class_new(gensym("zexy/pack"), (t_newmethod)zpack_new,
(t_method)zpack_free, sizeof(t_zpack), 0, A_GIMME, 0);
#if 0
- /* oops Pd-0.42 allows us to override built-ins
+ /* oops Pd>=0.42 allows us to override built-ins
* this is bad as long as the 2 objects are not compatible */
class_addcreator((t_newmethod)zpack_new, gensym("pack"), A_GIMME, 0);
#endif
class_addbang(zpack_class, zpack_bang);
- class_addlist(zpack_class, zpack_list0);
+ class_addlist(zpack_class, zpack_list);
+ class_addanything(zpack_class, zpack_any);
zpackproxy_class = class_new(gensym("zpack proxy"), 0, 0,
sizeof(t_zpackproxy),
CLASS_PD | CLASS_NOINLET, 0);
- class_addlist(zpackproxy_class, zpack_list);
-
+ class_addlist(zpackproxy_class, zpack_proxy_list);
+ class_addanything(zpackproxy_class, zpack_proxy_any);
zexy_register("pack");
}
diff --git a/src/unpack.c b/src/unpack.c
index 0ec3641..c18861c 100644
--- a/src/unpack.c
+++ b/src/unpack.c
@@ -1,21 +1,30 @@
-/******************************************************
+/*
+ * unpack: a type-agnostic version of [unpack]
*
- * zexy - implementation file
+ * (c) 2007-2011 IOhannes m zmölnig, forum::für::umläute, institute of electronic music and acoustics (iem)
*
- * copyleft (c) IOhannes m zmölnig
+ * 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. If not, see <http://www.gnu.org/licenses/>.
+/*
+
+/*
+ * this version of [unpack] does not care about types, so the arguments are merely there for documentation reasons
+ * (and to determine the number of outlets)
+ * e.g. sending [symbol foo( to [zexy/unpack 0] will output [symbol foo(
*
- * 1999:forum::für::umläute:2004
- *
- * institute of electronic music and acoustics (iem)
- *
- ******************************************************
- *
- * license: GNU General Public License v.2
- *
- ******************************************************/
-
+ * for know this object is named [zexy/unpack], as there might be some issues with compatibility with the original [unpack]
+ */
-/* 2305:forum::für::umläute:2001 */
#include "zexy.h"
@@ -32,13 +41,23 @@ typedef struct _zunpack
t_int x_numouts;
} t_zunpack;
-static void zunpack_list(t_zunpack *x, t_symbol *s, int argc, t_atom *argv)
+static void zunpack_any(t_zunpack *x, t_symbol *s, int argc, t_atom *argv)
{
- int count=(argc<(x->x_numouts))?argc:x->x_numouts;
+ int offset=(s!=NULL)?1:0;
+ int count=((argc+offset)<(x->x_numouts))?(argc+offset):x->x_numouts;
- while(count--) {
- outlet_list(x->x_out[count], gensym("list"), 1, argv+count);
+ while(count-->offset) {
+ outlet_list(x->x_out[count], gensym("list"), 1, argv+count-offset);
}
+
+ if(s!=NULL) {
+ outlet_symbol(x->x_out[0], s);
+ }
+}
+
+static void zunpack_list(t_zunpack *x, t_symbol *s, int argc, t_atom *argv)
+{
+ zunpack_any(x, 0, argc, argv);
}
static void zunpack_bang(t_zunpack *x)
@@ -88,6 +107,7 @@ void zunpack_setup(void)
class_addbang(zunpack_class, zunpack_bang);
class_addlist(zunpack_class, zunpack_list);
+ class_addanything(zunpack_class, zunpack_any);
zexy_register("unpack");
}