diff options
Diffstat (limited to 'pdstring+wchar/src')
-rw-r--r-- | pdstring+wchar/src/Makefile.am | 16 | ||||
-rw-r--r-- | pdstring+wchar/src/Makefile.in | 52 | ||||
-rw-r--r-- | pdstring+wchar/src/any2bytes-help.pd (renamed from pdstring+wchar/src/any2string-help.pd) | 25 | ||||
-rw-r--r-- | pdstring+wchar/src/any2bytes.c (renamed from pdstring+wchar/src/any2string.c) | 82 | ||||
-rw-r--r-- | pdstring+wchar/src/any2string_static.c | 246 | ||||
-rw-r--r-- | pdstring+wchar/src/bytes2any-help.pd (renamed from pdstring+wchar/src/string2any-help.pd) | 25 | ||||
-rw-r--r-- | pdstring+wchar/src/bytes2any.c (renamed from pdstring+wchar/src/string2any.c) | 68 | ||||
-rw-r--r-- | pdstring+wchar/src/config.h.in | 10 | ||||
-rw-r--r-- | pdstring+wchar/src/pdstring-help.pd | 52 | ||||
-rw-r--r-- | pdstring+wchar/src/pdstring.c | 13 | ||||
-rw-r--r-- | pdstring+wchar/src/unsigned.pd | 52 |
11 files changed, 196 insertions, 445 deletions
diff --git a/pdstring+wchar/src/Makefile.am b/pdstring+wchar/src/Makefile.am index 73d1366..69e2efb 100644 --- a/pdstring+wchar/src/Makefile.am +++ b/pdstring+wchar/src/Makefile.am @@ -32,8 +32,8 @@ pdexterns_PROGRAMS = @PD_OBJECT_EXTERNALS@ ## --- possible externals EXTRA_PROGRAMS = \ pdstring \ - any2string \ - string2any + any2bytes \ + bytes2any ## --- patches pdexterns_DATA = @@ -41,8 +41,8 @@ pdexterns_DATA = ## --- documentation pddoc_DATA = \ pdstring-help.pd \ - any2string-help.pd \ - string2any-help.pd + any2bytes-help.pd \ + bytes2any-help.pd #----------------------------------------------------------------------- @@ -51,9 +51,9 @@ pddoc_DATA = \ pdstring_SOURCES = pdstring.c mooPdUtils.h -any2string_SOURCES = any2string.c mooPdUtils.h +any2bytes_SOURCES = any2bytes.c mooPdUtils.h -string2any_SOURCES = string2any.c mooPdUtils.h +bytes2any_SOURCES = bytes2any.c mooPdUtils.h #----------------------------------------------------------------------- # external compilation : flags @@ -74,9 +74,9 @@ AM_CFLAGS = $(OFLAGS) $(WFLAGS) $(AFLAGS) pdstring_LDFLAGS = $(LFLAGS) -string2any_LDFLAGS = $(LFLAGS) +bytes2any_LDFLAGS = $(LFLAGS) -any2string_LDFLAGS = $(LFLAGS) +any2bytes_LDFLAGS = $(LFLAGS) #----------------------------------------------------------------------- # Variables: cleanup diff --git a/pdstring+wchar/src/Makefile.in b/pdstring+wchar/src/Makefile.in index f454607..5f5b1ae 100644 --- a/pdstring+wchar/src/Makefile.in +++ b/pdstring+wchar/src/Makefile.in @@ -50,8 +50,8 @@ NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : pdexterns_PROGRAMS = @PD_OBJECT_EXTERNALS@ -EXTRA_PROGRAMS = pdstring$(EXEEXT) any2string$(EXEEXT) \ - string2any$(EXEEXT) +EXTRA_PROGRAMS = pdstring$(EXEEXT) any2bytes$(EXEEXT) \ + bytes2any$(EXEEXT) subdir = src SUBDIRS = DIST_COMMON = $(srcdir)/Makefile.am $(srcdir)/Makefile.in \ @@ -67,15 +67,15 @@ am__installdirs = "$(DESTDIR)$(pdexternsdir)" "$(DESTDIR)$(pddocdir)" \ "$(DESTDIR)$(pdexternsdir)" pdexternsPROGRAMS_INSTALL = $(INSTALL_PROGRAM) PROGRAMS = $(pdexterns_PROGRAMS) -am_any2string_OBJECTS = any2string.$(OBJEXT) -any2string_OBJECTS = $(am_any2string_OBJECTS) -any2string_LDADD = $(LDADD) +am_any2bytes_OBJECTS = any2bytes.$(OBJEXT) +any2bytes_OBJECTS = $(am_any2bytes_OBJECTS) +any2bytes_LDADD = $(LDADD) +am_bytes2any_OBJECTS = bytes2any.$(OBJEXT) +bytes2any_OBJECTS = $(am_bytes2any_OBJECTS) +bytes2any_LDADD = $(LDADD) am_pdstring_OBJECTS = pdstring.$(OBJEXT) pdstring_OBJECTS = $(am_pdstring_OBJECTS) pdstring_LDADD = $(LDADD) -am_string2any_OBJECTS = string2any.$(OBJEXT) -string2any_OBJECTS = $(am_string2any_OBJECTS) -string2any_LDADD = $(LDADD) DEFAULT_INCLUDES = -I. -I$(srcdir) -I. depcomp = $(SHELL) $(top_srcdir)/config/depcomp am__depfiles_maybe = depfiles @@ -83,10 +83,10 @@ COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) CCLD = $(CC) LINK = $(CCLD) $(AM_CFLAGS) $(CFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ -SOURCES = $(any2string_SOURCES) $(pdstring_SOURCES) \ - $(string2any_SOURCES) -DIST_SOURCES = $(any2string_SOURCES) $(pdstring_SOURCES) \ - $(string2any_SOURCES) +SOURCES = $(any2bytes_SOURCES) $(bytes2any_SOURCES) \ + $(pdstring_SOURCES) +DIST_SOURCES = $(any2bytes_SOURCES) $(bytes2any_SOURCES) \ + $(pdstring_SOURCES) RECURSIVE_TARGETS = all-recursive check-recursive dvi-recursive \ html-recursive info-recursive install-data-recursive \ install-exec-recursive install-info-recursive \ @@ -207,24 +207,24 @@ SUFFIXES = .@PDEXT@ pdexterns_DATA = pddoc_DATA = \ pdstring-help.pd \ - any2string-help.pd \ - string2any-help.pd + any2bytes-help.pd \ + bytes2any-help.pd #----------------------------------------------------------------------- # sources #----------------------------------------------------------------------- pdstring_SOURCES = pdstring.c mooPdUtils.h -any2string_SOURCES = any2string.c mooPdUtils.h -string2any_SOURCES = string2any.c mooPdUtils.h +any2bytes_SOURCES = any2bytes.c mooPdUtils.h +bytes2any_SOURCES = bytes2any.c mooPdUtils.h #GLIB_IFLAGS = @GLIB_IFLAGS@ #GLIB_LFLAGS = @GLIB_LFLAGS@ AM_CPPFLAGS = $(IFLAGS) $(GLIB_IFLAGS) $(DFLAGS) AM_CFLAGS = $(OFLAGS) $(WFLAGS) $(AFLAGS) pdstring_LDFLAGS = $(LFLAGS) -string2any_LDFLAGS = $(LFLAGS) -any2string_LDFLAGS = $(LFLAGS) +bytes2any_LDFLAGS = $(LFLAGS) +any2bytes_LDFLAGS = $(LFLAGS) #----------------------------------------------------------------------- # Variables: cleanup @@ -332,15 +332,15 @@ uninstall-pdexternsPROGRAMS: clean-pdexternsPROGRAMS: -test -z "$(pdexterns_PROGRAMS)" || rm -f $(pdexterns_PROGRAMS) -any2string$(EXEEXT): $(any2string_OBJECTS) $(any2string_DEPENDENCIES) - @rm -f any2string$(EXEEXT) - $(LINK) $(any2string_LDFLAGS) $(any2string_OBJECTS) $(any2string_LDADD) $(LIBS) +any2bytes$(EXEEXT): $(any2bytes_OBJECTS) $(any2bytes_DEPENDENCIES) + @rm -f any2bytes$(EXEEXT) + $(LINK) $(any2bytes_LDFLAGS) $(any2bytes_OBJECTS) $(any2bytes_LDADD) $(LIBS) +bytes2any$(EXEEXT): $(bytes2any_OBJECTS) $(bytes2any_DEPENDENCIES) + @rm -f bytes2any$(EXEEXT) + $(LINK) $(bytes2any_LDFLAGS) $(bytes2any_OBJECTS) $(bytes2any_LDADD) $(LIBS) pdstring$(EXEEXT): $(pdstring_OBJECTS) $(pdstring_DEPENDENCIES) @rm -f pdstring$(EXEEXT) $(LINK) $(pdstring_LDFLAGS) $(pdstring_OBJECTS) $(pdstring_LDADD) $(LIBS) -string2any$(EXEEXT): $(string2any_OBJECTS) $(string2any_DEPENDENCIES) - @rm -f string2any$(EXEEXT) - $(LINK) $(string2any_LDFLAGS) $(string2any_OBJECTS) $(string2any_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) @@ -348,9 +348,9 @@ mostlyclean-compile: distclean-compile: -rm -f *.tab.c -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/any2string.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/any2bytes.Po@am__quote@ +@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bytes2any.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pdstring.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/string2any.Po@am__quote@ .c.o: @am__fastdepCC_TRUE@ if $(COMPILE) -MT $@ -MD -MP -MF "$(DEPDIR)/$*.Tpo" -c -o $@ $<; \ diff --git a/pdstring+wchar/src/any2string-help.pd b/pdstring+wchar/src/any2bytes-help.pd index 873070c..215a27f 100644 --- a/pdstring+wchar/src/any2string-help.pd +++ b/pdstring+wchar/src/any2bytes-help.pd @@ -1,12 +1,9 @@ #N canvas 90 20 636 478 10; -#X obj 25 400 print any2string-help; -#X obj 25 314 any2string 128 -1; #X msg 109 197 0; #X msg 77 197 -1; #X text 19 47 INLETS:; #X text 31 61 1 - pd messages; #X text 247 49 OUTLETS:; -#X text 263 63 1 - lists of ASCII-valued floats; #X floatatom 44 147 8 0 0 0 - - -; #X symbolatom 34 125 10 0 0 0 - - -; #X text 189 125 ... no special handling for symbols; @@ -21,19 +18,23 @@ text buffer). This should get re-allocated when necessary. Specify #X text 320 458 Bryan Jurish <moocow@ling.uni-potsdam.de>; #X text 19 439 SEE ALSO:; #X msg 139 197 42; -#X text 21 29 SYNTAX: any2string [INITIAL_BUFSIZE [EOS_CHAR]]; #X text 184 194 The second inlet sets the terminating EOS ("end-of-string") character. This value gets implicitly appended to all output lists. Specify a negative value here to avoid implicit EOS characters entirely. For backwards compatibility \, the default EOS character is 0 (zero). ; -#X text 51 5 any2string : convert pd messages to a list of floats; #X text 31 75 2 - EOS character (float); #X obj 100 438 pdstring; -#X connect 1 0 0 0; -#X connect 2 0 1 1; -#X connect 3 0 1 1; -#X connect 8 0 1 0; -#X connect 9 0 1 0; -#X connect 13 0 1 0; -#X connect 18 0 1 1; +#X obj 25 314 any2bytes 128 -1; +#X obj 25 400 print any2bytes-help; +#X text 21 29 SYNTAX: any2bytes [INITIAL_BUFSIZE [EOS_CHAR]]; +#X text 263 63 1 - lists of byte-valued floats; +#X text 49 5 any2bytes : convert pd messages to a list of byte values +; +#X connect 0 0 19 1; +#X connect 1 0 19 1; +#X connect 5 0 19 0; +#X connect 6 0 19 0; +#X connect 10 0 19 0; +#X connect 15 0 19 1; +#X connect 19 0 20 0; diff --git a/pdstring+wchar/src/any2string.c b/pdstring+wchar/src/any2bytes.c index deb4b9b..f765f6f 100644 --- a/pdstring+wchar/src/any2string.c +++ b/pdstring+wchar/src/any2bytes.c @@ -1,10 +1,10 @@ /* -*- Mode: C -*- */ /*=============================================================================*\ - * File: any2string.c + * File: any2bytes.c * Author: Bryan Jurish <moocow@ling.uni-potsdam.de> * Description: convert pd messages to strings (dynamic allocation) * - * Copyright (c) 2004 - 2009 Bryan Jurish. + * Copyright (c) 2004-2009 Bryan Jurish. * * For information on usage and redistribution, and for a DISCLAIMER OF ALL * WARRANTIES, see the file "COPYING", in this distribution. @@ -41,23 +41,23 @@ /*-------------------------------------------------------------------- * DEBUG *--------------------------------------------------------------------*/ -/*#define ANY2STRING_DEBUG 1*/ +/*#define ANY2BYTES_DEBUG 1*/ -#ifdef ANY2STRING_DEBUG +#ifdef ANY2BYTES_DEBUG # define A2SDEBUG(x) x #else # define A2SDEBUG(x) #endif -#define ANY2STRING_DEFAULT_BUFLEN 256 +#define ANY2BYTES_DEFAULT_BUFLEN 256 /*===================================================================== - * Structures and Types: any2string + * Structures and Types: any2bytes *=====================================================================*/ -static t_class *any2string_class; +static t_class *any2bytes_class; -typedef struct _any2string +typedef struct _any2bytes { t_object x_obj; int x_alloc; @@ -68,13 +68,13 @@ typedef struct _any2string t_binbuf *x_binbuf; t_inlet *x_eos_in; t_outlet *x_outlet; -} t_any2string; +} t_any2bytes; /*===================================================================== * Constants *=====================================================================*/ -static char *any2string_banner = "any2string: pdstring version " PACKAGE_VERSION " by Bryan Jurish"; +static char *any2bytes_banner = "any2bytes: pdstring version " PACKAGE_VERSION " by Bryan Jurish"; /*===================================================================== * Methods @@ -83,65 +83,65 @@ static char *any2string_banner = "any2string: pdstring version " PACKAGE_VERSION /*-------------------------------------------------------------------- * anything */ -static void any2string_anything(t_any2string *x, t_symbol *sel, int argc, t_atom *argv) +static void any2bytes_anything(t_any2bytes *x, t_symbol *sel, int argc, t_atom *argv) { t_atom *ap; unsigned char *s, *s_max; int len; - A2SDEBUG(post("-------any2string_anything(%p,...)---------", x)); + A2SDEBUG(post("-------any2bytes_anything(%p,...)---------", x)); /*-- set up binbuf --*/ - A2SDEBUG(post("any2string[%p]: binbuf_clear()", x)); + A2SDEBUG(post("any2bytes[%p]: binbuf_clear()", x)); binbuf_clear(x->x_binbuf); /*-- binbuf_add(): selector --*/ if (sel != &s_float && sel != &s_list && sel != &s_) { t_atom a; - A2SDEBUG(post("any2string[%p]: binbuf_add(): selector: '%s'", x, sel->s_name)); + A2SDEBUG(post("any2bytes[%p]: binbuf_add(): selector: '%s'", x, sel->s_name)); SETSYMBOL((&a), sel); binbuf_add(x->x_binbuf, 1, &a); } - A2SDEBUG(else { post("any2string[%p]: selector: '%s': IGNORED", x, sel->s_name); }); + A2SDEBUG(else { post("any2bytes[%p]: selector: '%s': IGNORED", x, sel->s_name); }); /*-- binbuf_add(): arg list --*/ - A2SDEBUG(post("any2string[%p]: binbuf_add(): arg list", x)); + A2SDEBUG(post("any2bytes[%p]: binbuf_add(): arg list", x)); binbuf_add(x->x_binbuf, argc, argv); - A2SDEBUG(post("any2string[%p]: binbuf_print: ", x)); + A2SDEBUG(post("any2bytes[%p]: binbuf_print: ", x)); A2SDEBUG(binbuf_print(x->x_binbuf)); - A2SDEBUG(post("any2string[%p]: binbuf_gettext()", x)); + A2SDEBUG(post("any2bytes[%p]: binbuf_gettext()", x)); binbuf_gettext(x->x_binbuf, &(x->x_text), &len); - A2SDEBUG(post("any2string[%p]: binbuf_gettext() = \"%s\" ; len=%d", x, x->x_text, len)); + A2SDEBUG(post("any2bytes[%p]: binbuf_gettext() = \"%s\" ; len=%d", x, x->x_text, len)); /*text[len] = 0;*/ /*-- ? avoid errors: "free(): invalid next size(fast): 0x..." */ /*-- get output atom-list length --*/ x->x_argc = len; if (x->x_eos >= 0) { x->x_argc++; } - A2SDEBUG(post("any2string[%p]: argc=%d", x, x->x_argc)); + A2SDEBUG(post("any2bytes[%p]: argc=%d", x, x->x_argc)); /*-- (re-)allocate (maybe) --*/ if (x->x_alloc < x->x_argc) { - A2SDEBUG(post("any2string[%p]: reallocate(%d->%d)", x, x->x_alloc, x->x_argc)); + A2SDEBUG(post("any2bytes[%p]: reallocate(%d->%d)", x, x->x_alloc, x->x_argc)); freebytes(x->x_argv, x->x_alloc*sizeof(t_atom)); x->x_argv = (t_atom*)getbytes(x->x_argc * sizeof(t_atom)); x->x_alloc = x->x_argc; } /*-- atom buffer: binbuf text --*/ - A2SDEBUG(post("any2string[%p]: atom buffer: for {...}", x)); + A2SDEBUG(post("any2bytes[%p]: atom buffer: for {...}", x)); ap = x->x_argv; s_max = ((unsigned char *)x->x_text)+len; for (s=((unsigned char *)x->x_text); s < s_max; s++, ap++) { - A2SDEBUG(post("any2string[%p]: atom buffer[%d]: SETFLOAT(a,%d='%c')", x, (ap-x->x_argv), *s, *s)); + A2SDEBUG(post("any2bytes[%p]: atom buffer[%d]: SETFLOAT(a,%d='%c')", x, (ap-x->x_argv), *s, *s)); SETFLOAT(ap,*s); } - A2SDEBUG(post("any2string: atom buffer: DONE")); + A2SDEBUG(post("any2bytes: atom buffer: DONE")); /*-- add EOS character (maybe) --*/ if (x->x_eos >= 0) { SETFLOAT(ap, ((int)x->x_eos)); } - A2SDEBUG(post("any2string: outlet_list(..., %d, ...)", x->x_argc)); + A2SDEBUG(post("any2bytes: outlet_list(..., %d, ...)", x->x_argc)); outlet_list(x->x_outlet, &s_list, x->x_argc, x->x_argv); } @@ -149,13 +149,13 @@ static void any2string_anything(t_any2string *x, t_symbol *sel, int argc, t_atom /*-------------------------------------------------------------------- * new */ -static void *any2string_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) +static void *any2bytes_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) { - t_any2string *x = (t_any2string *)pd_new(any2string_class); + t_any2bytes *x = (t_any2bytes *)pd_new(any2bytes_class); //-- defaults x->x_eos = 0; - x->x_alloc = ANY2STRING_DEFAULT_BUFLEN; + x->x_alloc = ANY2BYTES_DEFAULT_BUFLEN; //-- args: 0: bufsize if (argc > 0) { @@ -180,7 +180,7 @@ static void *any2string_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) x->x_outlet = outlet_new(&x->x_obj, &s_list); //-- report - A2SDEBUG(post("any2string_new(): x=%p, alloc=%d, eos=%d, text=%p, argv=%p, binbuf=%p", x, x->x_alloc, x->x_eos, x->x_text, x->x_argv, x->x_binbuf)); + A2SDEBUG(post("any2bytes_new(): x=%p, alloc=%d, eos=%d, text=%p, argv=%p, binbuf=%p", x, x->x_alloc, x->x_eos, x->x_text, x->x_argv, x->x_binbuf)); return (void *)x; } @@ -188,7 +188,7 @@ static void *any2string_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) /*-------------------------------------------------------------------- * free */ -static void any2string_free(t_any2string *x) +static void any2bytes_free(t_any2bytes *x) { if (x->x_text) { freebytes(x->x_text, x->x_alloc*sizeof(char)); @@ -207,33 +207,33 @@ static void any2string_free(t_any2string *x) /*-------------------------------------------------------------------- * setup (guts) */ -void any2string_setup_guts(void) +void any2bytes_setup_guts(void) { //-- class - any2string_class = class_new(gensym("any2string"), - (t_newmethod)any2string_new, - (t_method)any2string_free, - sizeof(t_any2string), + any2bytes_class = class_new(gensym("any2bytes"), + (t_newmethod)any2bytes_new, + (t_method)any2bytes_free, + sizeof(t_any2bytes), CLASS_DEFAULT, A_GIMME, //-- initial_bufsize, eos_char 0); //-- alias - class_addcreator((t_newmethod)any2string_new, gensym("any2bytes"), A_GIMME, 0); + class_addcreator((t_newmethod)any2bytes_new, gensym("any2string"), A_GIMME, 0); //-- methods - class_addanything(any2string_class, (t_method)any2string_anything); + class_addanything(any2bytes_class, (t_method)any2bytes_anything); //-- help symbol - //class_sethelpsymbol(any2string_class, gensym("any2string-help.pd")); //-- breaks pd-extended help lookup + //class_sethelpsymbol(any2bytes_class, gensym("any2bytes-help.pd")); //-- breaks pd-extended help lookup } /*-------------------------------------------------------------------- * setup */ -void any2string_setup(void) +void any2bytes_setup(void) { - post(any2string_banner); - any2string_setup_guts(); + post(any2bytes_banner); + any2bytes_setup_guts(); } diff --git a/pdstring+wchar/src/any2string_static.c b/pdstring+wchar/src/any2string_static.c deleted file mode 100644 index 50da35d..0000000 --- a/pdstring+wchar/src/any2string_static.c +++ /dev/null @@ -1,246 +0,0 @@ -/* -*- Mode: C -*- */ -/*=============================================================================*\ - * File: any2string_static.c - * Author: Bryan Jurish <moocow@ling.uni-potsdam.de> - * Description: convert pd messages to strings (static buffer allocation) - * - * Copyright (c) 2004 - 2007 Bryan Jurish. - * - * For information on usage and redistribution, and for a DISCLAIMER OF ALL - * WARRANTIES, see the file "COPYING", in this distribution. - * - * 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, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - *=============================================================================*/ - -#include <string.h> -#include <stdio.h> - -#include <m_pd.h> - -#ifdef HAVE_CONFIG_H -# include "config.h" -#endif - -/* black magic */ -#ifdef NT -#pragma warning( disable : 4244 ) -#pragma warning( disable : 4305 ) -#endif - -/*-------------------------------------------------------------------- - * DEBUG - *--------------------------------------------------------------------*/ -/*#define ANY2STRING_DEBUG 1*/ -/*#undef ANY2STRING_DEBUG*/ - -#ifdef ANY2STRING_DEBUG -# define A2SDEBUG(x) x -#else -# define A2SDEBUG(x) -#endif - -#define ANY2STRING_DEFAULT_BUFLEN 512 - - -/*===================================================================== - * Structures and Types: any2string - *=====================================================================*/ -static t_class *any2string_class; - -typedef struct _any2string -{ - t_object x_obj; - int x_alloc; //-- buffer size (text, x_argv) - int x_argc; //-- current number of atoms to outlet - t_atom *x_argv; //-- float-list to outlet - t_outlet *x_outlet; //-- outlet -} t_any2string; - - -/*===================================================================== - * Utilities - *=====================================================================*/ - -/*-------------------------------------------------------------------- - * append_string - */ -static void any2string_append_string(t_any2string *x, char *s, unsigned int maxlen, int doescape) -{ - char *sp; - char *ep = s+maxlen; - - for (sp=s; *sp && sp<ep && *sp && x->x_argc<x->x_alloc; sp++, x->x_argc++) { - if (doescape && (*sp==';' || *sp==',' || *sp=='\\' - || (*sp == '$' && sp<(ep-1) && sp[1] >= '0' && sp[1] <= '9'))) - { - A2SDEBUG(post("any2string_append_string: ESCAPE: x_argv[%d] = '%c' = %d", x->x_argc, '\\', '\\')); - x->x_argv[x->x_argc++].a_w.w_float = '\\'; - if (x->x_argc >= x->x_alloc) break; - } - A2SDEBUG(post("any2string_append_string: x_argv[%d] = '%c' = %d", x->x_argc, *sp, *sp)); - x->x_argv[x->x_argc].a_w.w_float = *sp; - } -} - -/*-------------------------------------------------------------------- - * append_atom - */ -#define ANY2STRING_APPEND_BUFSIZE 30 -static void any2string_append_atom(t_any2string *x, t_atom *a) -{ - char buf[ANY2STRING_APPEND_BUFSIZE]; - A2SDEBUG(post("~~ any2string_append_atom(%p,...) ~~", x)); - - if (x->x_argc >= x->x_alloc) { return; } - - /*-- stringify a single atom (inspired by atom_string() from m_atom.c) --*/ - switch (a->a_type) { - case A_SEMI: any2string_append_string(x, ";", 1, 0); break; - case A_COMMA: any2string_append_string(x, ",", 1, 0); break; - case A_POINTER: any2string_append_string(x, "(pointer)", 9, 0); break; - case A_FLOAT: - snprintf(buf, ANY2STRING_APPEND_BUFSIZE, "%g", a->a_w.w_float); - any2string_append_string(x, buf, ANY2STRING_APPEND_BUFSIZE, 0); - break; - case A_SYMBOL: - any2string_append_string(x, a->a_w.w_symbol->s_name, strlen(a->a_w.w_symbol->s_name), 1); - break; - case A_DOLLAR: - snprintf(buf, ANY2STRING_APPEND_BUFSIZE, "$%d", a->a_w.w_index); - any2string_append_string(x, buf, ANY2STRING_APPEND_BUFSIZE, 0); - break; - case A_DOLLSYM: - any2string_append_string(x, a->a_w.w_symbol->s_name, strlen(a->a_w.w_symbol->s_name), 0); - break; - default: - pd_error(x,"any2string_append_atom: unknown atom type '%d'", a->a_type); - break; - } - - if (x->x_argc < x->x_alloc) { - A2SDEBUG(post("any2string_append_atom[%p]: x_argv[%d] = '%c' = %d", x, x->x_argc, ' ', ' ')); - x->x_argv[x->x_argc++].a_w.w_float = ' '; - } -} - -/*===================================================================== - * Methods - *=====================================================================*/ - -/*-------------------------------------------------------------------- - * anything - */ -static void any2string_anything(t_any2string *x, t_symbol *sel, int argc, t_atom *argv) -{ - t_atom *argv_end = argv+argc; - x->x_argc=0; - - A2SDEBUG(post("-------any2string_anything(%p,...) ---------", x)); - - /*-- stringify selector (maybe) --*/ - if (sel != &s_float && sel != &s_list && sel != &s_) { - t_atom a; - SETSYMBOL(&a,sel); - any2string_append_atom(x, &a); - } - - /*-- stringify arg list --*/ - for ( ; argv<argv_end && x->x_argc<x->x_alloc; argv++) { - any2string_append_atom(x, argv); - } - - /*-- add terminating NUL (if we can) --*/ - A2SDEBUG(post("any2string[%p]: terminating NUL: x_argv[%d]=0", x, x->x_argc-1)); - if (x->x_argc >= x->x_alloc) { - pd_error(x, "any2string: input length exceeds buffer size!"); - x->x_argc = x->x_alloc; - x->x_argv[x->x_argc-1].a_w.w_float = '*'; //-- simulate atom_string() behavior - } else if (x->x_argc > 0) { - x->x_argv[x->x_argc-1].a_w.w_float = 0; - } - - A2SDEBUG(post("any2string[%p]: outlet_list(..., %d, ...)", x, x->x_argc)); - outlet_list(x->x_outlet, &s_list, x->x_argc, x->x_argv); -} - - -/*-------------------------------------------------------------------- - * new - */ -static void *any2string_new(t_floatarg bufsize) -{ - t_any2string *x = (t_any2string *)pd_new(any2string_class); - int i; - - //-- bufsize - if (bufsize <= 0) { - x->x_alloc = ANY2STRING_DEFAULT_BUFLEN; - } else { - x->x_alloc = bufsize; - } - A2SDEBUG(post("any2string_new: buf_req=%g, alloc=%d", bufsize, x->x_alloc)); - - //-- defaults - x->x_argc = 0; - x->x_argv = (t_atom*)getbytes(x->x_alloc*sizeof(t_atom)); - - //-- initialize (set a_type) - for (i=0; i < x->x_alloc; i++) { - SETFLOAT((x->x_argv+i),0); - } - - //-- outlets - x->x_outlet = outlet_new(&x->x_obj, &s_list); - A2SDEBUG(post("any2string_new: x=%p, alloc=%d, argv=%p, nbytes=%d", x, x->x_alloc,x->x_argv,x->x_alloc*sizeof(t_atom))); - return (void *)x; -} - -/*-------------------------------------------------------------------- - * free - */ -static void any2string_free(t_any2string *x) -{ - A2SDEBUG(post("any2string_free(x=%p)", x)); - if (x->x_argv) { - A2SDEBUG(post("any2string_free(x=%p): x_argv=%p (size=%d)", x, x->x_argv, x->x_alloc*sizeof(t_atom))); - freebytes(x->x_argv, x->x_alloc*sizeof(t_atom)); - } - A2SDEBUG(post("any2string_free(x=%p): x_outlet=%p", x, x->x_outlet)); - outlet_free(x->x_outlet); - return; -} - -/*-------------------------------------------------------------------- - * setup - */ -void any2string_setup(void) -{ - //-- class - any2string_class = class_new(gensym("any2string"), - (t_newmethod)any2string_new, - (t_method)any2string_free, - sizeof(t_any2string), - CLASS_DEFAULT, - A_DEFFLOAT, - 0); - - //-- methods - class_addanything(any2string_class, - (t_method)any2string_anything); - - - //-- help symbol - class_sethelpsymbol(any2string_class, gensym("pdstring-help.pd")); -} diff --git a/pdstring+wchar/src/string2any-help.pd b/pdstring+wchar/src/bytes2any-help.pd index 3d09fc7..0a8e138 100644 --- a/pdstring+wchar/src/string2any-help.pd +++ b/pdstring+wchar/src/bytes2any-help.pd @@ -1,8 +1,5 @@ -#N canvas 121 48 612 604 10; -#X text 59 7 string2any : convert lists of floats to pd messages; -#X text 13 30 SYNTAX: string2any [INITIAL_BUFSIZE [EOS_CHAR]]; +#N canvas 179 42 612 604 10; #X text 13 52 INLETS:; -#X text 27 68 1 - ASCII-valued float lists; #X text 309 54 OUTLETS:; #X text 325 68 1 - pd messages; #X text 325 82 2 - bang on done; @@ -36,11 +33,15 @@ has been processed.; #X text 168 161 ... selector is ignored ...; #X text 21 571 SEE ALSO:; #X obj 102 570 pdstring; -#X connect 7 0 8 0; -#X connect 7 1 9 0; -#X connect 10 0 7 0; -#X connect 11 0 7 0; -#X connect 12 0 7 1; -#X connect 13 0 7 1; -#X connect 14 0 7 1; -#X connect 23 0 7 0; +#X text 27 68 1 - byte-valued float lists; +#X text 59 7 bytes2any : convert lists of byte values to pd messages +; +#X text 13 30 SYNTAX: bytes2any [INITIAL_BUFSIZE [EOS_CHAR]]; +#X connect 4 0 5 0; +#X connect 4 1 6 0; +#X connect 7 0 4 0; +#X connect 8 0 4 0; +#X connect 9 0 4 1; +#X connect 10 0 4 1; +#X connect 11 0 4 1; +#X connect 20 0 4 0; diff --git a/pdstring+wchar/src/string2any.c b/pdstring+wchar/src/bytes2any.c index 73eaae9..f4cb9d1 100644 --- a/pdstring+wchar/src/string2any.c +++ b/pdstring+wchar/src/bytes2any.c @@ -1,10 +1,10 @@ /* -*- Mode: C -*- */ /*=============================================================================*\ - * File: string2any.c + * File: bytes2any.c * Author: Bryan Jurish <moocow@ling.uni-potsdam.de> * Description: convert strings to pd messages * - * Copyright (c) 2004-2008 Bryan Jurish. + * Copyright (c) 2004-2009 Bryan Jurish. * * For information on usage and redistribution, and for a DISCLAIMER OF ALL * WARRANTIES, see the file "COPYING", in this distribution. @@ -41,30 +41,30 @@ /*-------------------------------------------------------------------- * DEBUG *--------------------------------------------------------------------*/ -/*#define STRING2ANY_DEBUG 1*/ -/*#undef STRING2ANY_DEBUG*/ +/*#define BYTES2ANY_DEBUG 1*/ +/*#undef BYTES2ANY_DEBUG*/ -#ifdef STRING2ANY_DEBUG +#ifdef BYTES2ANY_DEBUG # define S2ADEBUG(x) x #else # define S2ADEBUG(x) #endif -#define STRING2ANY_DEFAULT_BUFLEN 256 +#define BYTES2ANY_DEFAULT_BUFLEN 256 /*===================================================================== * Constants *=====================================================================*/ -static char *string2any_banner = "string2any: pdstring version " PACKAGE_VERSION " by Bryan Jurish"; +static char *bytes2any_banner = "bytes2any: pdstring version " PACKAGE_VERSION " by Bryan Jurish"; /*===================================================================== * Structures and Types: any2string *=====================================================================*/ -static t_class *string2any_class; +static t_class *bytes2any_class; -typedef struct _string2any +typedef struct _bytes2any { t_object x_obj; size_t x_size; @@ -74,7 +74,7 @@ typedef struct _string2any t_inlet *x_eos_in; t_outlet *x_outlet; t_outlet *x_outlet_done; -} t_string2any; +} t_bytes2any; /*===================================================================== @@ -82,9 +82,9 @@ typedef struct _string2any *=====================================================================*/ /*-------------------------------------------------------------------- - * string2any_atoms() + * bytes2any_atoms() */ -static void string2any_atoms(t_string2any *x, int argc, t_atom *argv) +static void bytes2any_atoms(t_bytes2any *x, int argc, t_atom *argv) { char *s; int x_argc, a_argc=0; @@ -100,16 +100,16 @@ static void string2any_atoms(t_string2any *x, int argc, t_atom *argv) /*-- get text --*/ for (s=x->x_text; argc > 0; argc--, a_argc++, argv++, s++) { *s = atom_getfloat(argv); - S2ADEBUG(post("string2any[%p]: a_argc=%d,*s=%d", x, a_argc, *s)); + S2ADEBUG(post("bytes2any[%p]: a_argc=%d,*s=%d", x, a_argc, *s)); if ((x->x_eos<0 && !*s) || (*s==x->x_eos)) { break; } /*-- hack: look for eos char --*/ } *s = 0; - S2ADEBUG(post("string2any[%p]: text: \"%s\", strlen=%d, argc=%d", x, x->x_text, strlen(x->x_text), a_argc)); + S2ADEBUG(post("bytes2any[%p]: text: \"%s\", strlen=%d, argc=%d", x, x->x_text, strlen(x->x_text), a_argc)); /*-- clear and fill binbuf --*/ binbuf_clear(x->x_binbuf); binbuf_text(x->x_binbuf, x->x_text, a_argc); //-- handle NULs if binbuf will (but it won't) ? - S2ADEBUG(post("string2any[%p]: binbuf_print: ", x)); + S2ADEBUG(post("bytes2any[%p]: binbuf_print: ", x)); S2ADEBUG(binbuf_print(x->x_binbuf)); /*-- output --*/ @@ -137,7 +137,7 @@ static void string2any_atoms(t_string2any *x, int argc, t_atom *argv) /*-------------------------------------------------------------------- * anything */ -static void string2any_anything(t_string2any *x, MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) +static void bytes2any_anything(t_bytes2any *x, MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) { int i0=0, i; @@ -145,14 +145,14 @@ static void string2any_anything(t_string2any *x, MOO_UNUSED t_symbol *sel, int a if (x->x_eos >= 0) { for (i=i0; i < argc; i++) { if (((int)atom_getfloatarg(i,argc,argv))==((int)x->x_eos)) { - string2any_atoms(x, i-i0, argv+i0); + bytes2any_atoms(x, i-i0, argv+i0); i0=i+1; } } } if (i0 < argc) { - string2any_atoms(x, argc-i0, argv+i0); + bytes2any_atoms(x, argc-i0, argv+i0); } outlet_bang(x->x_outlet_done); @@ -162,13 +162,13 @@ static void string2any_anything(t_string2any *x, MOO_UNUSED t_symbol *sel, int a /*-------------------------------------------------------------------- * new */ -static void *string2any_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) +static void *bytes2any_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) { - t_string2any *x = (t_string2any *)pd_new(string2any_class); + t_bytes2any *x = (t_bytes2any *)pd_new(bytes2any_class); //-- defaults x->x_binbuf = binbuf_new(); - x->x_size = STRING2ANY_DEFAULT_BUFLEN; + x->x_size = BYTES2ANY_DEFAULT_BUFLEN; x->x_eos = -1; //-- args: 0: bufsize @@ -193,7 +193,7 @@ static void *string2any_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) x->x_outlet_done = outlet_new(&x->x_obj, &s_bang); //-- debug - S2ADEBUG(post("string2any_new: x=%p, size=%d, eos=%d, binbuf=%p, text=%p", x, x->x_size, x->x_eos, x->x_binbuf, x->x_text)); + S2ADEBUG(post("bytes2any_new: x=%p, size=%d, eos=%d, binbuf=%p, text=%p", x, x->x_size, x->x_eos, x->x_binbuf, x->x_text)); return (void *)x; } @@ -201,7 +201,7 @@ static void *string2any_new(MOO_UNUSED t_symbol *sel, int argc, t_atom *argv) /*-------------------------------------------------------------------- * free */ -static void string2any_free(t_string2any *x) +static void bytes2any_free(t_bytes2any *x) { if (x->x_text) { freebytes(x->x_text, x->x_size*sizeof(char)); @@ -217,33 +217,33 @@ static void string2any_free(t_string2any *x) /*-------------------------------------------------------------------- * setup: guts */ -void string2any_setup_guts(void) +void bytes2any_setup_guts(void) { //-- class - string2any_class = class_new(gensym("string2any"), - (t_newmethod)string2any_new, - (t_method)string2any_free, - sizeof(t_string2any), + bytes2any_class = class_new(gensym("bytes2any"), + (t_newmethod)bytes2any_new, + (t_method)bytes2any_free, + sizeof(t_bytes2any), CLASS_DEFAULT, A_GIMME, //-- initial_bufsize, eos_char 0); //-- alias - class_addcreator((t_newmethod)string2any_new, gensym("bytes2any"), A_GIMME, 0); + class_addcreator((t_newmethod)bytes2any_new, gensym("bytes2any"), A_GIMME, 0); //-- methods - class_addanything(string2any_class, (t_method)string2any_anything); + class_addanything(bytes2any_class, (t_method)bytes2any_anything); //-- help symbol - //class_sethelpsymbol(string2any_class, gensym("string2any-help.pd")); //-- breaks pd-extended help lookup + //class_sethelpsymbol(bytes2any_class, gensym("bytes2any-help.pd")); //-- breaks pd-extended help lookup } /*-------------------------------------------------------------------- * setup */ -void string2any_setup(void) +void bytes2any_setup(void) { - post(string2any_banner); - string2any_setup_guts(); + post(bytes2any_banner); + bytes2any_setup_guts(); } diff --git a/pdstring+wchar/src/config.h.in b/pdstring+wchar/src/config.h.in index fe4add7..748fa6a 100644 --- a/pdstring+wchar/src/config.h.in +++ b/pdstring+wchar/src/config.h.in @@ -1,7 +1,10 @@ /* src/config.h.in. Generated from configure.ac by autoheader. */ -/* Define this to include debugging code for the 'string2any' external. */ -#undef ANY2STRING_DEBUG +/* Define this to include debugging code for the 'bytes2any' external. */ +#undef ANY2BYTES_DEBUG + +/* Define this to include debugging code for the 'any2bytes' external. */ +#undef BYTES2ANY_DEBUG /* Define to 1 if you have the <string.h> header file. */ #undef HAVE_STRING_H @@ -33,8 +36,5 @@ /* User who configured this external */ #undef PDSTRING_USER -/* Define this to include debugging code for the 'any2string' external. */ -#undef STRING2ANY_DEBUG - /* Version number of package */ #undef VERSION diff --git a/pdstring+wchar/src/pdstring-help.pd b/pdstring+wchar/src/pdstring-help.pd index 2ab94b3..12e6d42 100644 --- a/pdstring+wchar/src/pdstring-help.pd +++ b/pdstring+wchar/src/pdstring-help.pd @@ -4,8 +4,6 @@ #X symbolatom 46 59 10 0 0 0 - - -; #X text 201 59 ... no special handling for symbols; #X text 200 37 anything can be converted to a list...; -#X obj 37 108 any2string; -#X obj 37 230 string2any; #X floatatom 54 178 4 0 0 0 - - -; #X text 213 230 string2any converts ASCII lists to Pd messages...; #X text 202 81 ... but "float" selector is silently dropped; @@ -13,7 +11,6 @@ #X obj 162 144 f 0; #X obj 134 153 + 1; #X obj 161 165 t f f f; -#X obj 133 198 string2any; #X obj 154 243 pack s 0; #X obj 162 119 until; #X obj 133 218 symbol; @@ -23,37 +20,40 @@ #X obj 162 54 t b b; #X obj 154 266 route list; #X obj 154 293 print charset; +#X obj 133 198 bytes2any; #X connect 0 0 2 0; #X connect 1 0 0 1; #X connect 2 0 1 0; -#X connect 2 1 3 0; -#X connect 2 2 4 1; -#X connect 3 0 6 0; -#X connect 4 0 11 0; -#X connect 5 0 0 0; +#X connect 2 1 12 0; +#X connect 2 2 3 1; +#X connect 3 0 10 0; +#X connect 4 0 0 0; +#X connect 5 0 3 0; #X connect 6 0 4 0; -#X connect 7 0 5 0; -#X connect 8 0 0 1; -#X connect 9 0 10 0; -#X connect 10 0 7 0; -#X connect 10 1 8 0; -#X connect 11 0 12 0; -#X connect 11 1 12 0; +#X connect 7 0 0 1; +#X connect 8 0 9 0; +#X connect 9 0 6 0; +#X connect 9 1 7 0; +#X connect 10 0 11 0; +#X connect 10 1 11 0; +#X connect 12 0 5 0; #X restore 249 144 pd ascii-table; #X msg 249 121 bang; #X text 361 143 know your charset; -#X obj 58 139 print any2string-out; -#X obj 37 254 print string2any-out; #X msg 37 38 A B C; #X msg 55 199 list 49 50 51; #X text 54 3 any2string \, string2any : ASCII conversions in [pdstring] lib; -#X connect 1 0 5 0; -#X connect 2 0 5 0; -#X connect 5 0 13 0; -#X connect 5 0 6 0; -#X connect 6 0 14 0; -#X connect 7 0 6 0; -#X connect 11 0 10 0; -#X connect 15 0 5 0; -#X connect 16 0 6 0; +#X obj 37 108 any2bytes; +#X obj 37 230 bytes2any; +#X obj 58 139 print any2bytes-out; +#X obj 37 254 print bytes2any-out; +#X connect 1 0 14 0; +#X connect 2 0 14 0; +#X connect 5 0 15 0; +#X connect 9 0 8 0; +#X connect 11 0 14 0; +#X connect 12 0 15 0; +#X connect 14 0 15 0; +#X connect 14 0 16 0; +#X connect 15 0 17 0; diff --git a/pdstring+wchar/src/pdstring.c b/pdstring+wchar/src/pdstring.c index 44add2d..d68cbdd 100644 --- a/pdstring+wchar/src/pdstring.c +++ b/pdstring+wchar/src/pdstring.c @@ -55,13 +55,8 @@ typedef struct _pdstring * External declarations *=====================================================================*/ #ifndef PDSTRING_OBJECT_EXTERNALS -/* -extern void any2string_setup_guts(void); -extern void string2any_setup_guts(void); -*/ -#include "any2string.c" -#include "string2any.c" - +# include "any2bytes.c" +# include "bytes2any.c" #endif /*-------------------------------------------------------------------- @@ -91,8 +86,8 @@ void pdstring_setup(void) pdstring_help(NULL); #ifndef PDSTRING_OBJECT_EXTERNALS - any2string_setup_guts(); - string2any_setup_guts(); + any2bytes_setup_guts(); + bytes2any_setup_guts(); #endif pdstring_class = class_new(gensym("pdstring"), diff --git a/pdstring+wchar/src/unsigned.pd b/pdstring+wchar/src/unsigned.pd index 7a5a328..d86c773 100644 --- a/pdstring+wchar/src/unsigned.pd +++ b/pdstring+wchar/src/unsigned.pd @@ -1,27 +1,27 @@ #N canvas 206 54 450 300 10; -#X floatatom 105 86 5 0 0 1 byte_value - -; -#X obj 105 116 string2any; -#X obj 119 146 print s2a; -#X obj 105 176 any2string; -#X floatatom 105 208 5 0 0 0 - - -; -#X msg 105 48 -10; -#X msg 143 48 246; -#X floatatom 238 207 5 0 0 0 - - -; -#X floatatom 240 82 5 0 0 1 byte_value - -; -#X msg 240 49 -10; -#X msg 278 49 246; -#X obj 238 115 bytes2any; -#X obj 238 175 any2bytes; -#X obj 252 145 print s2b; -#X connect 0 0 1 0; -#X connect 1 0 2 0; -#X connect 1 0 3 0; -#X connect 3 0 4 0; -#X connect 5 0 0 0; -#X connect 6 0 0 0; -#X connect 8 0 11 0; -#X connect 9 0 8 0; -#X connect 10 0 8 0; -#X connect 11 0 12 0; -#X connect 11 0 13 0; -#X connect 12 0 7 0; +#X floatatom 253 98 5 0 0 1 byte_value - -; +#X obj 267 158 print s2a; +#X floatatom 253 220 5 0 0 0 - - -; +#X msg 253 60 -10; +#X msg 291 60 246; +#X floatatom 86 219 5 0 0 0 - - -; +#X floatatom 88 94 5 0 0 1 byte_value - -; +#X msg 88 61 -10; +#X msg 126 61 246; +#X obj 86 127 bytes2any; +#X obj 86 187 any2bytes; +#X obj 100 157 print s2b; +#X obj 253 128 string2any; +#X obj 253 188 any2string; +#X connect 0 0 12 0; +#X connect 3 0 0 0; +#X connect 4 0 0 0; +#X connect 6 0 9 0; +#X connect 7 0 6 0; +#X connect 8 0 6 0; +#X connect 9 0 10 0; +#X connect 9 0 11 0; +#X connect 10 0 5 0; +#X connect 12 0 1 0; +#X connect 12 0 13 0; +#X connect 13 0 2 0; |