From 18dbae9c9ffe5baa09e220c9f74af2dd7c0aa3f5 Mon Sep 17 00:00:00 2001 From: Thomas Grill Date: Fri, 1 Aug 2003 02:32:50 +0000 Subject: "" svn path=/trunk/; revision=810 --- externals/grill/flext/changes.txt | 2 + externals/grill/flext/source/flatom.cpp | 13 ++++ externals/grill/flext/source/flatom_pr.cpp | 16 ++++- externals/grill/flext/source/flattr.cpp | 96 ++++++++++++++++++++++++++---- externals/grill/flext/source/flattr_ed.cpp | 2 +- externals/grill/flext/source/flclass.h | 36 ++++++++--- externals/grill/flext/source/flmsg.cpp | 2 +- externals/grill/flext/source/flsupport.h | 5 ++ 8 files changed, 148 insertions(+), 24 deletions(-) (limited to 'externals') diff --git a/externals/grill/flext/changes.txt b/externals/grill/flext/changes.txt index 67496aa0..d17a2e51 100644 --- a/externals/grill/flext/changes.txt +++ b/externals/grill/flext/changes.txt @@ -28,6 +28,7 @@ Version history: - make use of new PD thread locking (PD functions sys_lock() and sys_unlock()) - better FLEXT_OSAPI resolution - ListAttributes (or the getattributes message) now lists attributes in the order they were created (first class, then object scope) +- enforcing usage of STL 0.4.4: - fixed deadly bug for Max/MSP method-to-symbol-binding proxies @@ -257,6 +258,7 @@ Restrictions in compatibility mode: Porting to new compilers/platforms: - enums must be int-sized!!! - compiler must support bool type +- an STL implementation must exist - no need of C++ exceptions or RTTI (RTTI only for GUI objects) BUT: some libraries could use RTTI and then need run-time type information from the library! (this is known for gcc compiles) diff --git a/externals/grill/flext/source/flatom.cpp b/externals/grill/flext/source/flatom.cpp index 45739e66..afed8dec 100644 --- a/externals/grill/flext/source/flatom.cpp +++ b/externals/grill/flext/source/flatom.cpp @@ -91,6 +91,19 @@ int flext::AtomList::Compare(const AtomList &a) const return Count() < a.Count()?-1:1; } +std::string flext::AtomList::Print() const +{ + char buffer[256]; + std::string ret; + for(int i = 0; i < Count(); ++i) { + char *b = buffer; + if(i) *(b++) = ' '; // prepend space + PrintAtom((*this)[i],b,sizeof buffer-1); + ret += buffer; + } + return ret; +} + #if FLEXT_SYS != FLEXT_SYS_JMAX // not for jmax as long as t_symbol * == char * diff --git a/externals/grill/flext/source/flatom_pr.cpp b/externals/grill/flext/source/flatom_pr.cpp index e4989320..639bca63 100644 --- a/externals/grill/flext/source/flatom_pr.cpp +++ b/externals/grill/flext/source/flatom_pr.cpp @@ -18,9 +18,23 @@ WARRANTIES, see the file, "license.txt," in this distribution. #include #include +// \TODO take bufsz into account! void flext::PrintAtom(const t_atom &a,char *buf,int bufsz) { - GetAString(a,buf,bufsz?bufsz:100000); + if(IsFloat(a)) { + sprintf(buf,"%g",GetFloat(a)); + } + else if(IsInt(a)) { + sprintf(buf,"%i",GetInt(a)); + } + else if(IsSymbol(a)) { + strcpy(buf,GetString(a)); + } + else if(IsPointer(a)) { + sprintf(buf,"%p",GetPointer(a)); + } + else + ERRINTERNAL(); } bool flext::ScanAtom(t_atom &a,const char *buf) diff --git a/externals/grill/flext/source/flattr.cpp b/externals/grill/flext/source/flattr.cpp index 40c811de..e754c87b 100644 --- a/externals/grill/flext/source/flattr.cpp +++ b/externals/grill/flext/source/flattr.cpp @@ -26,7 +26,8 @@ WARRANTIES, see the file, "license.txt," in this distribution. flext_base::AttrItem::AttrItem(const t_symbol *t,metharg tp,methfun f,int fl): Item(t,0,NULL),index(0), - flags(fl),argtp(tp),fun(f) + flags(fl|afl_shown),counter(NULL), + argtp(tp),fun(f) {} flext_base::AttrItem::~AttrItem() @@ -39,10 +40,11 @@ flext_base::AttrItem::~AttrItem() void flext_base::AddAttrib(ItemCont *aa,ItemCont *ma,const char *attr,metharg tp,methfun gfun,methfun sfun) { const t_symbol *asym = MakeSymbol(attr); + AttrItem *a,*b; if(sfun) // if commented out, there will be a warning at run-time (more user-friendly) { - AttrItem *a = new AttrItem(asym,tp,sfun,AttrItem::afl_bothexist|AttrItem::afl_set); + a = new AttrItem(asym,tp,sfun,AttrItem::afl_set); // set index of item to the next higher value AttrItem *last = (AttrItem *)aa->Last(); @@ -55,25 +57,34 @@ void flext_base::AddAttrib(ItemCont *aa,ItemCont *ma,const char *attr,metharg tp mi->SetArgs(sfun,1,new metharg(tp)); ma->Add(mi); } + else + a = NULL; if(gfun) // if commented out, there will be a warning at run-time (more user-friendly) { - AttrItem *a = new AttrItem(asym,tp,gfun,AttrItem::afl_bothexist|AttrItem::afl_get); + b = new AttrItem(asym,tp,gfun,AttrItem::afl_get); // set index of item to the next higher value AttrItem *last = (AttrItem *)aa->Last(); - if(last) a->index = last->index+1; + if(last) b->index = last->index+1; - aa->Add(a); + aa->Add(b); static char tmp[256] = "get"; strcpy(tmp+3,attr); // bind attribute to a method - MethItem *mi = new MethItem(0,MakeSymbol(tmp),a); + MethItem *mi = new MethItem(0,MakeSymbol(tmp),b); mi->SetArgs(gfun,0,NULL); ma->Add(mi); } + else + b = NULL; + + if(a && b) { + a->counter = b; + b->counter = a; + } } void flext_base::AddAttrib(const char *attr,metharg tp,methfun gfun,methfun sfun) @@ -300,7 +311,13 @@ bool flext_base::GetAttrib(AttrItem *a,AtomList &la) const return ok; } -bool flext_base::GetAttrib(AttrItem *a) +bool flext_base::GetAttrib(const t_symbol *s,AtomList &a) const +{ + AttrItem *attr = FindAttrib(s,true); + return attr && GetAttrib(attr,a); +} + +bool flext_base::DumpAttrib(AttrItem *a) const { AtomList la; bool ret = GetAttrib(a,la); @@ -308,15 +325,70 @@ bool flext_base::GetAttrib(AttrItem *a) return ret; } -bool flext_base::GetAttrib(const t_symbol *s,AtomList &a) const +bool flext_base::DumpAttrib(const t_symbol *attr) const { - AttrItem *attr = FindAttrib(s,true); - return attr && GetAttrib(attr,a); + AttrItem *item = FindAttrib(attr,true); + return item && DumpAttrib(item); } +bool flext_base::BangAttrib(AttrItem *item) +{ + AtomList val; + AttrItem *item2; + if(!item->IsGet()) + item = item->Counterpart(); + if(item) { + item2 = item->Counterpart(); + return item2 && GetAttrib(item,val) && SetAttrib(item2,val); + } + else + return false; +} -bool flext_base::DumpAttrib(const t_symbol *attr) const +bool flext_base::BangAttrib(const t_symbol *attr) +{ + AttrItem *item = FindAttrib(attr,true); + return item && BangAttrib(item); +} + +bool flext_base::BangAttribAll() +{ + int i,cnt = clattrhead->Ready()?clattrhead->Size():2; + for(i = 0; i < cnt; ++i) { + AttrItem *a = (AttrItem *)clattrhead->GetItem(i); + for(; a; a = (AttrItem *)a->nxt) { + if(a->IsGet() && a->BothExist()) + BangAttrib(a); + } + } + + cnt = attrhead->Ready()?attrhead->Size():2; + for(i = 0; i < cnt; ++i) { + AttrItem *a = (AttrItem *)attrhead->GetItem(i); + for(; a; a = (AttrItem *)a->nxt) { + if(a->IsGet() && a->BothExist()) + BangAttrib(a); + } + } + return true; +} + +bool flext_base::ShowAttrib(AttrItem *a,bool show) const +{ + if(show) a->flags |= AttrItem::afl_shown; + else a->flags &= ~AttrItem::afl_shown; + + // also change counterpart, if present + AttrItem *ca = a->Counterpart(); + if(ca) { + if(show) ca->flags |= AttrItem::afl_shown; + else ca->flags &= ~AttrItem::afl_shown; + } + return true; +} + +bool flext_base::ShowAttrib(const t_symbol *attr,bool show) const { AttrItem *item = FindAttrib(attr,true); - return item && const_cast(this)->GetAttrib(item); + return item && ShowAttrib(item,show); } diff --git a/externals/grill/flext/source/flattr_ed.cpp b/externals/grill/flext/source/flattr_ed.cpp index 8a5f6c7d..0722ea10 100644 --- a/externals/grill/flext/source/flattr_ed.cpp +++ b/externals/grill/flext/source/flattr_ed.cpp @@ -328,7 +328,7 @@ void flext_base::cb_GfxProperties(t_gobj *c, t_glist *) STD::sprintf(b, "} {"); b += strlen(b); // get puttable attribute - AttrItem *pattr = th->FindAttrib(GetSymbol(la[i]),false); + AttrItem *pattr = gattr->Counterpart(); if(pattr) { // if there is initialization data take this, otherwise take the current data diff --git a/externals/grill/flext/source/flclass.h b/externals/grill/flext/source/flclass.h index 0f7df9c2..f4328d1e 100644 --- a/externals/grill/flext/source/flclass.h +++ b/externals/grill/flext/source/flclass.h @@ -537,6 +537,17 @@ protected: //! Set an attribute value bool SetAttrib(const t_symbol *s,const AtomList &a) { return SetAttrib(s,a.Count(),a.Atoms()); } + // get and set the attribute + bool BangAttrib(const t_symbol *a); + // get and set the attribute + bool BangAttrib(const char *a) { return BangAttrib(MakeSymbol(a)); } + // get and set all (both get- and settables) + bool BangAttribAll(); + // show/hide the attribute + bool ShowAttrib(const t_symbol *a,bool show) const; + // show/hide the attribute + bool ShowAttrib(const char *a,bool show) { return ShowAttrib(MakeSymbol(a),show); } + //! List methods void ListMethods(AtomList &a,int inlet = 0) const; @@ -653,19 +664,22 @@ protected: virtual ~AttrItem(); enum { - afl_getset = 0x01, afl_get = 0x00, afl_set = 0x01, - afl_bothexist = 0x02, - afl_save = 0x04,afl_init = 0x08,afl_inited = 0x10 + afl_get = 0x01, afl_set = 0x02, + afl_getset = afl_get|afl_set, + afl_shown = 0x08 }; bool IsGet() const { return (flags&afl_getset) == afl_get; } bool IsSet() const { return (flags&afl_getset) == afl_set; } - bool BothExist() const { return (flags&afl_bothexist) != 0; } + bool IsShown() const { return (flags&afl_shown) != 0; } + bool BothExist() const { return counter != NULL; } + AttrItem *Counterpart() { return counter; } int index; int flags; metharg argtp; methfun fun; + AttrItem *counter; }; //! Represent a data value of an attribute @@ -768,8 +782,8 @@ private: static ItemCont *GetClassArr(t_classid,int ix); - ItemCont *methhead,*clmethhead; - ItemCont *bindhead; + mutable ItemCont *methhead,*clmethhead; + mutable ItemCont *bindhead; bool CallMeth(const MethItem &m,int argc,const t_atom *argv); bool FindMeth(int inlet,const t_symbol *s,int argc,const t_atom *argv); @@ -777,8 +791,8 @@ private: bool TryMethSym(const MethItem *m,int inlet,const t_symbol *t,const t_symbol *s); bool TryMethAny(const MethItem *m,int inlet,const t_symbol *t,const t_symbol *s,int argc,const t_atom *argv); - ItemCont *attrhead,*clattrhead; - AttrDataCont *attrdata; + mutable ItemCont *attrhead,*clattrhead; + mutable AttrDataCont *attrdata; AttrItem *FindAttrib(const t_symbol *tag,bool get,bool msg = false) const; @@ -787,11 +801,15 @@ private: bool ListMethods(int inlet = 0) const; bool ListAttrib() const; - bool GetAttrib(AttrItem *a); + bool DumpAttrib(AttrItem *a) const; bool GetAttrib(AttrItem *a,AtomList &l) const; bool SetAttrib(const t_symbol *s,int argc,const t_atom *argv); bool SetAttrib(AttrItem *a,int argc,const t_atom *argv); bool SetAttrib(AttrItem *a,const AtomList &l) { return SetAttrib(a,l.Count(),l.Atoms()); } + // get and set the attribute + bool BangAttrib(AttrItem *a); + // show/hide the attribute + bool ShowAttrib(AttrItem *a,bool show) const; static bool cb_ListMethods(flext_base *c,int argc,const t_atom *argv); static bool cb_ListAttrib(flext_base *c) { return c->ListAttrib(); } diff --git a/externals/grill/flext/source/flmsg.cpp b/externals/grill/flext/source/flmsg.cpp index 9b1eba40..3086ff74 100755 --- a/externals/grill/flext/source/flmsg.cpp +++ b/externals/grill/flext/source/flmsg.cpp @@ -82,7 +82,7 @@ bool flext_base::TryMethTag(const MethItem *m,int inlet,const t_symbol *t,int ar // attributes are treated differently if(m->attr->IsGet()) - return GetAttrib(m->attr); + return DumpAttrib(m->attr); else return SetAttrib(m->attr,argc,argv); } diff --git a/externals/grill/flext/source/flsupport.h b/externals/grill/flext/source/flsupport.h index 6db7a7b0..60b7db3d 100644 --- a/externals/grill/flext/source/flsupport.h +++ b/externals/grill/flext/source/flsupport.h @@ -17,6 +17,8 @@ WARRANTIES, see the file, "license.txt," in this distribution. #include "flstdc.h" +#include + class FLEXT_SHARE FLEXT_CLASSDEF(flext); typedef class FLEXT_CLASSDEF(flext) flext; @@ -523,6 +525,9 @@ public: //! Set to a part of the list AtomList &Part(int offs,int len) { return (*this = GetPart(offs,len)); } + //! Represent as a string + std::string Print() const; + protected: int cnt; t_atom *lst; -- cgit v1.2.1