aboutsummaryrefslogtreecommitdiff
path: root/externals/grill/flext/source
diff options
context:
space:
mode:
Diffstat (limited to 'externals/grill/flext/source')
-rw-r--r--externals/grill/flext/source/flbase.h4
-rw-r--r--externals/grill/flext/source/flclass.h48
-rw-r--r--externals/grill/flext/source/fldsp.cpp2
-rw-r--r--externals/grill/flext/source/fldsp.h2
-rw-r--r--externals/grill/flext/source/flext.h14
-rwxr-xr-xexternals/grill/flext/source/fllib.cpp8
-rwxr-xr-xexternals/grill/flext/source/flproxy.cpp41
-rw-r--r--externals/grill/flext/source/flsupport.cpp18
8 files changed, 108 insertions, 29 deletions
diff --git a/externals/grill/flext/source/flbase.h b/externals/grill/flext/source/flbase.h
index 795c0673..0587f919 100644
--- a/externals/grill/flext/source/flbase.h
+++ b/externals/grill/flext/source/flbase.h
@@ -250,7 +250,11 @@ class FLEXT_SHARE FLEXT_CLASSDEF(flext_obj):
static void obj_new(fts_object_t *o, int winlet, fts_symbol_t s, int ac, const fts_atom_t *at);
static void obj_free(fts_object_t *o, int winlet, fts_symbol_t s, int ac, const fts_atom_t *at);
#else
+#if FLEXT_SYS == FLEXT_SYS_MAX
+ static flext_hdr *obj_new(const t_symbol *s,short argc,t_atom *argv);
+#else
static flext_hdr *obj_new(const t_symbol *s,int argc,t_atom *argv);
+#endif
static void obj_free(flext_hdr *o);
#endif
diff --git a/externals/grill/flext/source/flclass.h b/externals/grill/flext/source/flclass.h
index 11661d67..20f5117c 100644
--- a/externals/grill/flext/source/flclass.h
+++ b/externals/grill/flext/source/flclass.h
@@ -849,24 +849,6 @@ private:
static void px_method(px_object *c,const t_symbol *s,int argc,t_atom *argv);
};
-#elif FLEXT_SYS == FLEXT_SYS_MAX
- typedef object px_object;
- static void cb_px_float(t_class *c,float f);
- static void cb_px_int(t_class *c,int v);
- static void cb_px_bang(t_class *c);
-
- static void cb_px_in1(t_class *c,int v);
- static void cb_px_in2(t_class *c,int v);
- static void cb_px_in3(t_class *c,int v);
- static void cb_px_in4(t_class *c,int v);
- static void cb_px_in5(t_class *c,int v);
- static void cb_px_in6(t_class *c,int v);
- static void cb_px_in7(t_class *c,int v);
- static void cb_px_in8(t_class *c,int v);
- static void cb_px_in9(t_class *c,int v);
-#endif
-
-#if FLEXT_SYS == FLEXT_SYS_PD || FLEXT_SYS == FLEXT_SYS_MAX
static void cb_px_anything(t_class *c,const t_symbol *s,int argc,t_atom *argv);
static void cb_px_ft1(t_class *c,float f);
@@ -879,6 +861,36 @@ private:
static void cb_px_ft8(t_class *c,float f);
static void cb_px_ft9(t_class *c,float f);
+#elif FLEXT_SYS == FLEXT_SYS_MAX
+ typedef object px_object;
+ static void cb_px_float(t_class *c,double f);
+ static void cb_px_int(t_class *c,long v);
+ static void cb_px_bang(t_class *c);
+
+ static void cb_px_in1(t_class *c,long v);
+ static void cb_px_in2(t_class *c,long v);
+ static void cb_px_in3(t_class *c,long v);
+ static void cb_px_in4(t_class *c,long v);
+ static void cb_px_in5(t_class *c,long v);
+ static void cb_px_in6(t_class *c,long v);
+ static void cb_px_in7(t_class *c,long v);
+ static void cb_px_in8(t_class *c,long v);
+ static void cb_px_in9(t_class *c,long v);
+
+ static void cb_px_ft1(t_class *c,double f);
+ static void cb_px_ft2(t_class *c,double f);
+ static void cb_px_ft3(t_class *c,double f);
+ static void cb_px_ft4(t_class *c,double f);
+ static void cb_px_ft5(t_class *c,double f);
+ static void cb_px_ft6(t_class *c,double f);
+ static void cb_px_ft7(t_class *c,double f);
+ static void cb_px_ft8(t_class *c,double f);
+ static void cb_px_ft9(t_class *c,double f);
+
+ static void cb_px_anything(t_class *c,const t_symbol *s,short argc,t_atom *argv);
+#endif
+
+#if FLEXT_SYS == FLEXT_SYS_PD || FLEXT_SYS == FLEXT_SYS_MAX
px_object **inlets;
#elif FLEXT_SYS == FLEXT_SYS_JMAX
static void jmax_proxy(fts_object_t *c, int winlet, fts_symbol_t s, int ac, const fts_atom_t *at);
diff --git a/externals/grill/flext/source/fldsp.cpp b/externals/grill/flext/source/fldsp.cpp
index 6d3298b2..9985464a 100644
--- a/externals/grill/flext/source/fldsp.cpp
+++ b/externals/grill/flext/source/fldsp.cpp
@@ -122,6 +122,8 @@ t_int *flext_dsp::dspmeth(t_int *w)
#if FLEXT_SYS == FLEXT_SYS_JMAX
void flext_dsp::cb_dsp(fts_object_t *c, int winlet, fts_symbol_t s, int ac, const fts_atom_t *at)
+#elif FLEXT_SYS == FLEXT_SYS_MAX
+void flext_dsp::cb_dsp(t_class *c,t_signal **sp,short *count)
#else
void flext_dsp::cb_dsp(t_class *c,t_signal **sp)
#endif
diff --git a/externals/grill/flext/source/fldsp.h b/externals/grill/flext/source/fldsp.h
index ee94973d..21a3aadb 100644
--- a/externals/grill/flext/source/fldsp.h
+++ b/externals/grill/flext/source/fldsp.h
@@ -155,6 +155,8 @@ private:
static void cb_dsp(fts_object_t *o, int winlet, fts_symbol_t s, int ac, const fts_atom_t *at);
// static void cb_dsp_init(fts_object_t *o, int winlet, fts_symbol_t *s, int ac, const fts_atom_t *at);
// static void cb_dsp_delete(fts_object_t *o, int winlet, fts_symbol_t *s, int ac, const fts_atom_t *at);
+#elif FLEXT_SYS == FLEXT_SYS_MAX
+ static void cb_dsp(t_class *c,t_signal **s,short *count);
#else
static void cb_dsp(t_class *c,t_signal **s);
#endif
diff --git a/externals/grill/flext/source/flext.h b/externals/grill/flext/source/flext.h
index 1a87e2bf..9fd63487 100644
--- a/externals/grill/flext/source/flext.h
+++ b/externals/grill/flext/source/flext.h
@@ -50,6 +50,13 @@ WARRANTIES, see the file, "license.txt," in this distribution.
#endif
#endif
+
+#if FLEXT_SYS == FLEXT_SYS_MAX && FLEXT_OS == FLEXT_OS_WIN
+// for wmax alignment must be 2 bytes!
+#pragma pack(2)
+#endif
+
+
// include all the flext interface definitions
#include "fldefs.h"
@@ -59,6 +66,9 @@ WARRANTIES, see the file, "license.txt," in this distribution.
// include the flext dsp class
#include "fldsp.h"
+/*
+#if FLEXT_SYS == FLEXT_SYS_MAX && FLEXT_OS == FLEXT_OS_WIN
+#pragma pack(pop)
+#endif
+*/
#endif // FLEXT_H
-
-
diff --git a/externals/grill/flext/source/fllib.cpp b/externals/grill/flext/source/fllib.cpp
index a6d95895..e1fc89c1 100755
--- a/externals/grill/flext/source/fllib.cpp
+++ b/externals/grill/flext/source/fllib.cpp
@@ -27,8 +27,10 @@ WARRANTIES, see the file, "license.txt," in this distribution.
#elif FLEXT_OS == FLEXT_OS_WIN
#if FLEXT_SYS == FLEXT_SYS_PD
#define ALIASSLASH '/'
+ #elif FLEXT_SYS == FLEXT_SYS_MAX
+ #define ALIASSLASH '/'
#else
- #error "Undefined"
+ #error "Undefined"
#endif
#else
// default to "/"
@@ -332,7 +334,11 @@ void flext_obj::obj_new(fts_object_t *o, int, fts_symbol_t s, int _argc_, const
{
flext_hdr *obj = (flext_hdr *)o;
#else
+#if FLEXT_SYS == FLEXT_SYS_MAX
+flext_hdr *flext_obj::obj_new(const t_symbol *s,short _argc_,t_atom *argv)
+#else
flext_hdr *flext_obj::obj_new(const t_symbol *s,int _argc_,t_atom *argv)
+#endif
{
flext_hdr *obj = NULL;
#endif
diff --git a/externals/grill/flext/source/flproxy.cpp b/externals/grill/flext/source/flproxy.cpp
index 2edcd4c9..85981130 100755
--- a/externals/grill/flext/source/flproxy.cpp
+++ b/externals/grill/flext/source/flproxy.cpp
@@ -43,17 +43,39 @@ add_method1(c,cb_px_ft ## IX,"ft" #IX,A_FLOAT)
#elif FLEXT_SYS == FLEXT_SYS_MAX
-void flext_base::cb_px_anything(t_class *c,const t_symbol *s,int argc,t_atom *argv)
+void flext_base::cb_px_anything(t_class *c,const t_symbol *s,short argc,t_atom *argv)
{
// check if inlet allows anything (or list)
flext_base *o = thisObject(c);
int ci = ((flext_hdr *)o->x_obj)->curinlet;
-
o->m_methodmain(ci,s,argc,argv);
}
-void flext_base::cb_px_int(t_class *c,int v)
+#if 0 //FLEXT_OS == FLEXT_OS_WIN
+// could also work for OSX!
+
+void flext_base::cb_px_int(t_class *c,long v)
+{
+ flext_base *o = thisObject(c);
+ int ci = proxy_getinlet((t_object *)o->x_obj);
+ // check if inlet allows int type
+ t_atom atom;
+ SetInt(atom,v);
+ o->m_methodmain(ci,sym_int,1,&atom);
+}
+
+void flext_base::cb_px_float(t_class *c,double v)
+{
+ flext_base *o = thisObject(c);
+ int ci = proxy_getinlet((t_object *)o->x_obj);
+ // check if inlet allows float type
+ t_atom atom;
+ SetFloat(atom,v);
+ o->m_methodmain(ci,sym_float,1,&atom);
+}
+#else
+void flext_base::cb_px_int(t_class *c,long v)
{
// check if inlet allows int type
t_atom atom;
@@ -61,13 +83,14 @@ void flext_base::cb_px_int(t_class *c,int v)
cb_px_anything(c,sym_int,1,&atom);
}
-void flext_base::cb_px_float(t_class *c,float v)
+void flext_base::cb_px_float(t_class *c,double v)
{
// check if inlet allows float type
t_atom atom;
SetFloat(atom,v);
cb_px_anything(c,sym_float,1,&atom);
}
+#endif
void flext_base::cb_px_bang(t_class *c)
{
@@ -77,8 +100,8 @@ void flext_base::cb_px_bang(t_class *c)
#define DEF_IN_FT(IX) \
-void flext_base::cb_px_in ## IX(t_class *c,int v) { long &ci = ((flext_hdr *)thisObject(c)->x_obj)->curinlet; ci = IX; cb_px_int(c,v); ci = 0; } \
-void flext_base::cb_px_ft ## IX(t_class *c,float v) { long &ci = ((flext_hdr *)thisObject(c)->x_obj)->curinlet; ci = IX; cb_px_float(c,v); ci = 0; }
+void flext_base::cb_px_in ## IX(t_class *c,long v) { long &ci = ((flext_hdr *)thisObject(c)->x_obj)->curinlet; ci = IX; cb_px_int(c,v); ci = 0; } \
+void flext_base::cb_px_ft ## IX(t_class *c,double v) { long &ci = ((flext_hdr *)thisObject(c)->x_obj)->curinlet; ci = IX; cb_px_float(c,v); ci = 0; }
#define ADD_IN_FT(IX) \
add_method1(c,cb_px_in ## IX,"in" #IX,A_INT); \
@@ -116,6 +139,11 @@ void flext_base::SetProxies(t_class *c)
#error Not implemented!
#endif
+#if 0 //FLEXT_SYS == FLEXT_SYS_MAX && FLEXT_OS == FLEXT_OS_WIN
+ // could also work for OSX!
+ addint((method)cb_px_int);
+ addfloat((method)cb_px_float);
+#else
// setup non-leftmost ints and floats
ADD_IN_FT(1);
ADD_IN_FT(2);
@@ -126,6 +154,7 @@ void flext_base::SetProxies(t_class *c)
ADD_IN_FT(7);
ADD_IN_FT(8);
ADD_IN_FT(9);
+#endif
}
#elif FLEXT_SYS == FLEXT_SYS_JMAX
diff --git a/externals/grill/flext/source/flsupport.cpp b/externals/grill/flext/source/flsupport.cpp
index 14b9bea5..b27196b8 100644
--- a/externals/grill/flext/source/flsupport.cpp
+++ b/externals/grill/flext/source/flsupport.cpp
@@ -174,6 +174,7 @@ int flext::Int2Bits(unsigned long n)
return b;
}
+
void flext::post(const char *fmt, ...)
{
#ifdef FLEXT_THREADS
@@ -182,9 +183,15 @@ void flext::post(const char *fmt, ...)
#endif
va_list ap;
va_start(ap, fmt);
+#if FLEXT_SYS == FLEXT_SYS_MAX
+ char buf[1024]; // \TODO this is quite unsafe.....
+ vsprintf(buf, fmt, ap);
+ ::post(buf);
+#else
vfprintf(stderr, fmt, ap);
+ ::post("");
+#endif
va_end(ap);
- putc('\n', stderr);
#ifdef FLEXT_THREADS
mutex.Unlock();
#endif
@@ -198,10 +205,17 @@ void flext::error(const char *fmt,...)
#endif
va_list ap;
va_start(ap, fmt);
+#if FLEXT_SYS == FLEXT_SYS_MAX
+ char buf[1024]; // \TODO this is quite unsafe.....
+ sprintf(buf,"error: ");
+ vsprintf(buf+7, fmt, ap);
+ ::post(buf);
+#else
fprintf(stderr, "error: ");
vfprintf(stderr, fmt, ap);
+ ::post("");
+#endif
va_end(ap);
- putc('\n', stderr);
#ifdef FLEXT_THREADS
mutex.Unlock();
#endif