diff options
Diffstat (limited to 'externals/grill/deljoin')
-rwxr-xr-x | externals/grill/deljoin/main.cpp | 77 |
1 files changed, 43 insertions, 34 deletions
diff --git a/externals/grill/deljoin/main.cpp b/externals/grill/deljoin/main.cpp index b52303cb..5dfdff5f 100755 --- a/externals/grill/deljoin/main.cpp +++ b/externals/grill/deljoin/main.cpp @@ -10,8 +10,8 @@ WARRANTIES, see the file, "license.txt," in this distribution. #include <flext.h> -#if !defined(FLEXT_VERSION) || (FLEXT_VERSION < 400) -#error You need at least flext version 0.4.0 +#if !defined(FLEXT_VERSION) || (FLEXT_VERSION < 401) +#error You need at least flext version 0.4.1 #endif #include <string.h> @@ -26,7 +26,7 @@ WARRANTIES, see the file, "license.txt," in this distribution. #define C char #define BL bool -#define VERSION "0.1.1" +#define VERSION "0.1.2" #ifdef __MWERKS__ #define STD std @@ -38,7 +38,7 @@ WARRANTIES, see the file, "license.txt," in this distribution. class deljoin: public flext_base { - FLEXT_HEADER(deljoin,flext_base) + FLEXT_HEADER_S(deljoin,flext_base,Setup) public: deljoin(I argc,const t_atom *argv); @@ -53,6 +53,8 @@ protected: virtual void m_assist(long /*msg*/,long /*arg*/,char * /*s*/); private: + static V Setup(t_class *c); + FLEXT_CALLBACK_A(m_list) FLEXT_CALLBACK_S(m_del) }; @@ -60,6 +62,12 @@ private: FLEXT_NEW_V("deljoin",deljoin) +V deljoin::Setup(t_class *c) +{ + FLEXT_CADDMETHOD_A(c,0,m_list); + FLEXT_CADDMETHOD(c,1,m_del); +} + deljoin::deljoin(I argc,const t_atom *argv): delim(NULL) { @@ -67,9 +75,6 @@ deljoin::deljoin(I argc,const t_atom *argv): AddInSymbol(); AddOutSymbol(); - FLEXT_ADDMETHOD_A(0,m_list); - FLEXT_ADDMETHOD(1,m_del); - if(argc && IsSymbol(argv[0])) delim = GetSymbol(argv[0]); } @@ -104,36 +109,40 @@ V deljoin::m_assist(long msg,long arg,char *s) */ V deljoin::m_list(const t_symbol *s,int argc,const t_atom *argv) { - C tmp[1024],*t = tmp; - const C *sdel = GetString(delim); - I ldel = strlen(sdel); - - if(s && s != sym_list && s != sym_float && s != sym_int) { - strcpy(t,GetString(s)); - t += strlen(t); - } - - for(int i = 0; i < argc; ++i) { - if(t != tmp) { - strcpy(t,sdel); - t += ldel; - } - - const t_atom &a = argv[i]; - if(IsSymbol(a)) - strcpy(t,GetString(a)); - else if(IsInt(a)) { - STD::sprintf(t,"%i",GetInt(a),10); + if(delim) { + C tmp[1024],*t = tmp; + const C *sdel = GetString(delim); + I ldel = strlen(sdel); + + if(s && s != sym_list && s != sym_float && s != sym_int) { + strcpy(t,GetString(s)); + t += strlen(t); } - else if(IsFloat(a)) { - STD::sprintf(t,"%f",GetFloat(a),10); + + for(int i = 0; i < argc; ++i) { + if(t != tmp) { + strcpy(t,sdel); + t += ldel; + } + + const t_atom &a = argv[i]; + if(IsSymbol(a)) + strcpy(t,GetString(a)); + else if(IsInt(a)) { + STD::sprintf(t,"%i",GetInt(a),10); + } + else if(IsFloat(a)) { + STD::sprintf(t,"%f",GetFloat(a),10); + } + // else do nothing + + t += strlen(t); } -// else do nothing - - t += strlen(t); + + ToOutString(0,tmp); } - - ToOutString(0,tmp); + else + post("%s - No delimiter defined",thisName()); } V deljoin::m_del(const t_symbol *s) |