From 50718bbb20fc634415d3ac6256fea29812efff6e Mon Sep 17 00:00:00 2001 From: Thomas Grill Date: Sat, 30 Sep 2006 19:23:16 +0000 Subject: reintroduced missing help message added success/error reporting for file operations fixed double-free on clearing values and dirs fixed bug in XML saving of nested folders changed obviously buggy pool name registering fixed clearing values and dirs, e.g. with messages clrall and clrrec use new ToSys* methods svn path=/trunk/; revision=6060 --- externals/grill/pool/pool-help.pd | 21 ++-- externals/grill/pool/pool.vcproj | 3 +- externals/grill/pool/readme.txt | 6 +- externals/grill/pool/source/data.cpp | 6 +- externals/grill/pool/source/main.cpp | 226 ++++++++++++++++++++--------------- externals/grill/pool/source/pool.cpp | 2 +- externals/grill/pool/source/pool.h | 4 +- 7 files changed, 155 insertions(+), 113 deletions(-) (limited to 'externals') diff --git a/externals/grill/pool/pool-help.pd b/externals/grill/pool/pool-help.pd index 0f3dfa9c..2b4a35c3 100644 --- a/externals/grill/pool/pool-help.pd +++ b/externals/grill/pool/pool-help.pd @@ -1,4 +1,4 @@ -#N canvas 4 3 947 717 12; +#N canvas 29 115 955 725 12; #X msg 296 105 set 1 2 3; #X obj 238 631 print K; #X msg 607 211 getall; @@ -40,8 +40,8 @@ #X text 673 208 bang at EOL; #X text 670 257 depth may be given; #X text 34 291 set pool name; -#X text 31 89 at each command; -#X text 31 73 echo current dir; +#X text 30 89 at each command; +#X text 30 73 echo current dir; #X text 295 82 set values; #X text 26 194 (default on); #X text 18 178 report absolute dirs; @@ -53,7 +53,7 @@ #X msg 609 366 cntrec; #X text 677 364 ... and subdirs; #X text 673 378 (depth may be given); -#N canvas 472 45 420 631 dirs 0; +#N canvas 472 45 424 635 dirs 0; #X msg 111 40 mkdir fld1; #X msg 113 135 chdir; #X msg 109 331 updir; @@ -99,7 +99,7 @@ #X connect 29 0 26 0; #X restore 716 496 pd dirs; #X text 713 470 directory operations; -#N canvas 0 22 833 465 file 0; +#N canvas 0 22 837 529 file 0; #X text 117 207 save dir and subdirs; #X text 117 165 save data in current dir; #X text 117 253 load data into current dir; @@ -134,6 +134,9 @@ #X msg 472 321 ldxrec pool.xml; #X text 26 398 If the file name is given without a path specification the folder containing the current patcher will be used.; +#X text 27 451 The attribute outlet reports if file saving/loading +has been successful \, by outputting the message tag and a boolean +flag.; #X connect 20 0 9 0; #X connect 21 0 9 0; #X connect 22 0 9 0; @@ -202,12 +205,12 @@ the folder containing the current patcher will be used.; #X msg 141 314 getpool; #X msg 297 345 add 2 14; #X obj 260 478 pool @valcnt 10 @dircnt 5; -#X text 330 437 expected value and directory counts; -#X text 330 452 can be given for optimal performance; +#X text 330 425 expected value and directory counts; +#X text 330 440 can be given for optimal performance; #X msg 429 155 get 3; #X msg 295 222 set 3 -1 1; #X msg 32 518 getmethods; -#X text 328 466 (see attributes in properties dialog); +#X text 328 454 (see attributes in properties dialog); #X text 715 638 console printout; #N canvas 0 22 612 291 print 0; #X obj 21 231 s \$0-pool; @@ -235,7 +238,7 @@ the folder containing the current patcher will be used.; #X msg 295 276 seti 3 Uhu; #X text 424 343 clear value at index; #X msg 425 363 clri 2; -#X text 272 13 a hierarchical storage object \, (C)2002-2005 Thomas +#X text 272 13 a hierarchical storage object \, (C)2002-2006 Thomas Grill; #X connect 0 0 69 0; #X connect 2 0 69 0; diff --git a/externals/grill/pool/pool.vcproj b/externals/grill/pool/pool.vcproj index 47a056a6..7aece276 100644 --- a/externals/grill/pool/pool.vcproj +++ b/externals/grill/pool/pool.vcproj @@ -3,6 +3,7 @@ ProjectType="Visual C++" Version="7.10" Name="pool" + ProjectGUID="{F6422672-C7DA-4DF1-9AFD-218947985297}" Keyword="Win32Proj"> PrintAll(tmp,sizeof tmp):0; + int cnt = pd?pd->PrintAll(tmp,sizeof tmp):0; + if(!cnt) post(tmp); + return cnt; } I pooldata::GetSub(const AtomList &d,const t_atom **&dirs) diff --git a/externals/grill/pool/source/main.cpp b/externals/grill/pool/source/main.cpp index 2f63f3d0..b8aa4f7d 100644 --- a/externals/grill/pool/source/main.cpp +++ b/externals/grill/pool/source/main.cpp @@ -2,7 +2,7 @@ pool - hierarchical storage object for PD and Max/MSP -Copyright (c) 2002-2005 Thomas Grill +Copyright (c) 2002-2006 Thomas Grill (gr@grrrr.org) For information on usage and redistribution, and for a DISCLAIMER OF ALL WARRANTIES, see the file, "license.txt," in this distribution. @@ -10,6 +10,7 @@ WARRANTIES, see the file, "license.txt," in this distribution. #include "pool.h" #include +#include #define POOL_VERSION "0.2.2pre" @@ -38,6 +39,8 @@ protected: V ms_pool(const AtomList &l); V mg_pool(AtomList &l); + V mg_priv(bool &p) const { p = pl && pl->Private(); } + // print some help message static V m_help() { post("pool " POOL_VERSION " - hierarchical storage object, (C)2002-2006 Thomas Grill"); } @@ -53,6 +56,8 @@ protected: V m_rmdir(I argc,const A *argv,BL abs = true); // remove dir V m_updir(I argc,const A *argv); // one or more levels up + V ms_curdir(const AtomList &l) { m_chdir(l.Count(),l.Atoms()); } + V m_mksub(I argc,const A *argv) { m_mkdir(argc,argv,false); } V m_mkchsub(I argc,const A *argv) { m_mkdir(argc,argv,false,true); } V m_chsub(I argc,const A *argv) { m_chdir(argc,argv,false); } @@ -120,6 +125,7 @@ private: V ToOutAtom(I ix,const A &a); static const t_symbol *sym_echo; + static const t_symbol *sym_error; enum get_t { get_norm,get_cnt,get_print }; @@ -142,14 +148,16 @@ private: V echodir() { if(echo) getdir(sym_echo); } - BL priv,absdir,echo; + BL absdir,echo; I vcnt,dcnt; pooldata *pl; Atoms curdir; pooldir *clip; - const S *holdname; - static pooldata *head,*tail; + static const S *holdname; // used during initialization of new object (between constructor and Init method) + + typedef std::map PoolMap; + static PoolMap poolmap; V SetPool(const S *s); V FreePool(); @@ -160,10 +168,11 @@ private: string MakeFilename(const C *fn) const; FLEXT_CALLVAR_V(mg_pool,ms_pool) + FLEXT_ATTRGET_V(curdir) + FLEXT_CALLSET_V(ms_curdir) FLEXT_ATTRVAR_B(absdir) FLEXT_ATTRVAR_B(echo) - FLEXT_ATTRGET_B(priv) -// FLEXT_ATTRGET_B(curdir) + FLEXT_CALLGET_B(mg_priv) FLEXT_ATTRVAR_I(vcnt) FLEXT_ATTRVAR_I(dcnt) @@ -232,8 +241,9 @@ private: FLEXT_NEW_V("pool",pool); -pooldata *pool::head,*pool::tail; -const t_symbol *pool::sym_echo; +pool::PoolMap pool::poolmap; +const t_symbol *pool::sym_echo,*pool::sym_error; +const t_symbol *pool::holdname; V pool::setup(t_classid c) @@ -242,13 +252,14 @@ V pool::setup(t_classid c) pool::m_help(); post(""); - head = tail = NULL; sym_echo = MakeSymbol("echo"); + sym_error = MakeSymbol("error"); FLEXT_CADDATTR_VAR(c,"pool",mg_pool,ms_pool); + FLEXT_CADDATTR_VAR(c,"curdir",curdir,ms_curdir); FLEXT_CADDATTR_VAR1(c,"absdir",absdir); FLEXT_CADDATTR_VAR1(c,"echodir",echo); - FLEXT_CADDATTR_GET(c,"private",priv); + FLEXT_CADDATTR_GET(c,"private",mg_priv); FLEXT_CADDATTR_VAR1(c,"valcnt",vcnt); FLEXT_CADDATTR_VAR1(c,"dircnt",dcnt); @@ -315,7 +326,7 @@ V pool::setup(t_classid c) pool::pool(I argc,const A *argv): absdir(true),echo(false), - pl(NULL),priv(false), + pl(NULL), clip(NULL), vcnt(VCNT),dcnt(DCNT) { @@ -345,7 +356,6 @@ BL pool::Init() V pool::SetPool(const S *s) { if(s) { - priv = false; if(pl) // check if new symbol equals the current one if(pl->sym == s) @@ -355,11 +365,13 @@ V pool::SetPool(const S *s) pl = GetPool(s); } else { - // if already private no need to allocate new storage - if(priv) return; - - priv = true; - if(pl) FreePool(); + if(pl) { + // if already private no need to allocate new storage + if(pl->Private()) + return; + else + FreePool(); + } pl = new pooldata(NULL,vcnt,dcnt); } } @@ -369,7 +381,7 @@ V pool::FreePool() curdir(); // reset current directory if(pl) { - if(!priv) + if(!pl->Private()) RmvPool(pl); else delete pl; @@ -393,7 +405,7 @@ V pool::ms_pool(const AtomList &l) V pool::mg_pool(AtomList &l) { - if(priv || !pl) l(); + if(!pl || pl->Private()) l(); else { l(1); SetSymbol(l[0],pl->sym); } } @@ -406,8 +418,8 @@ V pool::m_reset() V pool::getdir(const S *tag) { - ToOutAnything(3,tag,0,NULL); - ToOutList(2,curdir); + ToSysAnything(3,tag,0,NULL); + ToSysList(2,curdir); } V pool::m_getdir() { getdir(thisTag()); } @@ -582,18 +594,18 @@ V pool::m_get(I argc,const A *argv) poolval *r = pl->Ref(curdir,argv[0]); - ToOutAnything(3,thisTag(),0,NULL); + ToSysAnything(3,thisTag(),0,NULL); if(absdir) - ToOutList(2,curdir); + ToSysList(2,curdir); else - ToOutList(2,0,NULL); + ToSysList(2,0,NULL); if(r) { ToOutAtom(1,r->key); - ToOutList(0,*r->data); + ToSysList(0,*r->data); } else { - ToOutBang(1); - ToOutBang(0); + ToSysBang(1); + ToSysBang(0); } } @@ -607,18 +619,18 @@ V pool::m_geti(I ix) else { poolval *r = pl->Refi(curdir,ix); - ToOutAnything(3,thisTag(),0,NULL); + ToSysAnything(3,thisTag(),0,NULL); if(absdir) - ToOutList(2,curdir); + ToSysList(2,curdir); else - ToOutList(2,0,NULL); + ToSysList(2,0,NULL); if(r) { ToOutAtom(1,r->key); - ToOutList(0,*r->data); + ToSysList(0,*r->data); } else { - ToOutBang(1); - ToOutBang(0); + ToSysBang(1); + ToSysBang(0); } } @@ -647,10 +659,10 @@ I pool::getrec(const t_symbol *tag,I level,BL order,get_t how,const AtomList &rd post("%s - %s: error retrieving values",thisName(),GetString(tag)); else { for(I i = 0; i < cnt; ++i) { - ToOutAnything(3,tag,0,NULL); - ToOutList(2,absdir?gldir:rdir); + ToSysAnything(3,tag,0,NULL); + ToSysList(2,absdir?gldir:rdir); ToOutAtom(1,k[i]); - ToOutList(0,r[i]); + ToSysList(0,r[i]); } delete[] k; delete[] r; @@ -681,7 +693,7 @@ V pool::m_getall() { AtomList l; getrec(thisTag(),0,false,get_norm,l); - ToOutBang(3); + ToSysBang(3); echodir(); } @@ -690,7 +702,7 @@ V pool::m_ogetall() { AtomList l; getrec(thisTag(),0,true,get_norm,l); - ToOutBang(3); + ToSysBang(3); echodir(); } @@ -710,7 +722,7 @@ V pool::m_getrec(I argc,const A *argv) AtomList l; getrec(thisTag(),lvls,false,get_norm,l); - ToOutBang(3); + ToSysBang(3); echodir(); } @@ -731,7 +743,7 @@ V pool::m_ogetrec(I argc,const A *argv) AtomList l; getrec(thisTag(),lvls,true,get_norm,l); - ToOutBang(3); + ToSysBang(3); echodir(); } @@ -757,10 +769,10 @@ I pool::getsub(const S *tag,I level,BL order,get_t how,const AtomList &rdir) ++ret; if(how == get_norm) { - ToOutAnything(3,tag,0,NULL); - ToOutList(2,curdir); - ToOutList(1,ndir); - ToOutBang(0); + ToSysAnything(3,tag,0,NULL); + ToSysList(2,curdir); + ToSysList(1,ndir); + ToSysBang(0); } if(level != 0) { @@ -789,7 +801,7 @@ V pool::m_getsub(I argc,const A *argv) AtomList l; getsub(thisTag(),lvls,false,get_norm,l); - ToOutBang(3); + ToSysBang(3); echodir(); } @@ -810,7 +822,7 @@ V pool::m_ogetsub(I argc,const A *argv) AtomList l; getsub(thisTag(),lvls,true,get_norm,l); - ToOutBang(3); + ToSysBang(3); echodir(); } @@ -820,10 +832,10 @@ V pool::m_cntall() { AtomList l; I cnt = getrec(thisTag(),0,false,get_cnt,l); - ToOutSymbol(3,thisTag()); - ToOutBang(2); - ToOutBang(1); - ToOutInt(0,cnt); + ToSysSymbol(3,thisTag()); + ToSysBang(2); + ToSysBang(1); + ToSysInt(0,cnt); echodir(); } @@ -843,10 +855,10 @@ V pool::m_cntrec(I argc,const A *argv) AtomList l; I cnt = getrec(thisTag(),lvls,false,get_cnt,l); - ToOutSymbol(3,thisTag()); - ToOutBang(2); - ToOutBang(1); - ToOutInt(0,cnt); + ToSysSymbol(3,thisTag()); + ToSysBang(2); + ToSysBang(1); + ToSysInt(0,cnt); echodir(); } @@ -867,10 +879,10 @@ V pool::m_cntsub(I argc,const A *argv) AtomList l; I cnt = getsub(thisTag(),lvls,false,get_cnt,l); - ToOutSymbol(3,thisTag()); - ToOutBang(2); - ToOutBang(1); - ToOutInt(0,cnt); + ToSysSymbol(3,thisTag()); + ToSysBang(2); + ToSysBang(1); + ToSysInt(0,cnt); echodir(); } @@ -884,8 +896,7 @@ V pool::m_printall() V pool::m_printrec(I argc,const A *argv,BL fromroot) { - const S *tag = MakeSymbol(fromroot?"printroot":"printrec"); - + const S *tag = thisTag(); I lvls = -1; if(argc > 0) { if(CanbeInt(argv[0])) { @@ -992,20 +1003,25 @@ V pool::copyrec(const S *tag,I argc,const A *argv,BL cut) V pool::load(I argc,const A *argv,BL xml) { - const C *flnm = NULL; + const C *flnm = NULL; if(argc > 0) { if(argc > 1) post("%s - %s: superfluous arguments ignored",thisName(),GetString(thisTag())); if(IsString(argv[0])) flnm = GetString(argv[0]); } + bool ok = false; if(!flnm) post("%s - %s: no filename given",thisName(),GetString(thisTag())); else { string file(MakeFilename(flnm)); - if(!(xml?pl->LoadXML(file.c_str()):pl->Load(file.c_str()))) + ok = xml?pl->LoadXML(file.c_str()):pl->Load(file.c_str()); + if(!ok) post("%s - %s: error loading data",thisName(),GetString(thisTag())); } + t_atom at; SetBool(at,ok); + ToOutAnything(GetOutAttr(),thisTag(),1,&at); + echodir(); } @@ -1017,14 +1033,19 @@ V pool::save(I argc,const A *argv,BL xml) if(IsString(argv[0])) flnm = GetString(argv[0]); } + bool ok = false; if(!flnm) post("%s - %s: no filename given",thisName(),GetString(thisTag())); else { string file(MakeFilename(flnm)); - if(!(xml?pl->SaveXML(file.c_str()):pl->Save(file.c_str()))) + ok = xml?pl->SaveXML(file.c_str()):pl->Save(file.c_str()); + if(!ok) post("%s - %s: error saving data",thisName(),GetString(thisTag())); } + t_atom at; SetBool(at,ok); + ToOutAnything(GetOutAttr(),thisTag(),1,&at); + echodir(); } @@ -1036,14 +1057,19 @@ V pool::lddir(I argc,const A *argv,BL xml) if(IsString(argv[0])) flnm = GetString(argv[0]); } + bool ok = false; if(!flnm) post("%s - %s: invalid filename",thisName(),GetString(thisTag())); else { string file(MakeFilename(flnm)); - if(!(xml?pl->LdDirXML(curdir,file.c_str(),0):pl->LdDir(curdir,file.c_str(),0))) + ok = xml?pl->LdDirXML(curdir,file.c_str(),0):pl->LdDir(curdir,file.c_str(),0); + if(!ok) post("%s - %s: directory couldn't be loaded",thisName(),GetString(thisTag())); } + t_atom at; SetBool(at,ok); + ToOutAnything(GetOutAttr(),thisTag(),1,&at); + echodir(); } @@ -1070,14 +1096,19 @@ V pool::ldrec(I argc,const A *argv,BL xml) } } + bool ok = false; if(!flnm) post("%s - %s: invalid filename",thisName(),GetString(thisTag())); else { string file(MakeFilename(flnm)); - if(!(xml?pl->LdDirXML(curdir,file.c_str(),depth,mkdir):pl->LdDir(curdir,file.c_str(),depth,mkdir))) + ok = xml?pl->LdDirXML(curdir,file.c_str(),depth,mkdir):pl->LdDir(curdir,file.c_str(),depth,mkdir); + if(!ok) post("%s - %s: directory couldn't be saved",thisName(),GetString(thisTag())); } + t_atom at; SetBool(at,ok); + ToOutAnything(GetOutAttr(),thisTag(),1,&at); + echodir(); } @@ -1089,14 +1120,19 @@ V pool::svdir(I argc,const A *argv,BL xml) if(IsString(argv[0])) flnm = GetString(argv[0]); } + bool ok = false; if(!flnm) post("%s - %s: invalid filename",thisName(),GetString(thisTag())); else { string file(MakeFilename(flnm)); - if(!(xml?pl->SvDirXML(curdir,file.c_str(),0,absdir):pl->SvDir(curdir,file.c_str(),0,absdir))) - post("%s - %s: directory couldn't be saved",thisName(),GetString(thisTag())); + ok = xml?pl->SvDirXML(curdir,file.c_str(),0,absdir):pl->SvDir(curdir,file.c_str(),0,absdir); + if(!ok) + post("%s - %s: directory couldn't be saved",thisName(),GetString(thisTag())); } + t_atom at; SetBool(at,ok); + ToOutAnything(GetOutAttr(),thisTag(),1,&at); + echodir(); } @@ -1108,14 +1144,19 @@ V pool::svrec(I argc,const A *argv,BL xml) if(IsString(argv[0])) flnm = GetString(argv[0]); } + bool ok = false; if(!flnm) post("%s - %s: invalid filename",thisName(),GetString(thisTag())); else { string file(MakeFilename(flnm)); - if(!(xml?pl->SvDirXML(curdir,file.c_str(),-1,absdir):pl->SvDir(curdir,file.c_str(),-1,absdir))) - post("%s - %s: directory couldn't be saved",thisName(),GetString(thisTag())); + ok = xml?pl->SvDirXML(curdir,file.c_str(),-1,absdir):pl->SvDir(curdir,file.c_str(),-1,absdir); + if(!ok) + post("%s - %s: directory couldn't be saved",thisName(),GetString(thisTag())); } + t_atom at; SetBool(at,ok); + ToOutAnything(GetOutAttr(),thisTag(),1,&at); + echodir(); } @@ -1138,11 +1179,11 @@ BL pool::ValChk(I argc,const t_atom *argv) V pool::ToOutAtom(I ix,const t_atom &a) { if(IsSymbol(a)) - ToOutSymbol(ix,GetSymbol(a)); + ToSysSymbol(ix,GetSymbol(a)); else if(IsFloat(a)) - ToOutFloat(ix,GetFloat(a)); + ToSysFloat(ix,GetFloat(a)); else if(IsInt(a)) - ToOutInt(ix,GetInt(a)); + ToSysInt(ix,GetInt(a)); else post("%s - %s type not supported!",thisName(),GetString(thisTag())); } @@ -1151,36 +1192,25 @@ V pool::ToOutAtom(I ix,const t_atom &a) pooldata *pool::GetPool(const S *s) { - pooldata *pi = head; - for(; pi && pi->sym != s; pi = pi->nxt) (V)0; - - if(pi) { - pi->Push(); - return pi; - } - else { - pooldata *p = new pooldata(s); - p->Push(); - - // now add to chain - if(head) head->nxt = p; - else head = p; - tail = p; - return p; - } + PoolMap::iterator it = poolmap.find(s); + pooldata *p; + if(it != poolmap.end()) + p = it->second; + else + poolmap[s] = p = new pooldata(s); + p->Push(); + return p; } V pool::RmvPool(pooldata *p) { - pooldata *prv = NULL,*pi = head; - for(; pi && pi != p; prv = pi,pi = pi->nxt) (V)0; - - if(pi && !pi->Pop()) { - if(prv) prv->nxt = pi->nxt; - else head = pi->nxt; - if(!pi->nxt) tail = pi; - - delete pi; + FLEXT_ASSERT(p->sym); + PoolMap::iterator it = poolmap.find(p->sym); + FLEXT_ASSERT(it != poolmap.end()); + FLEXT_ASSERT(p == it->second); + if(!p->Pop()) { + poolmap.erase(it); + delete p; } } diff --git a/externals/grill/pool/source/pool.cpp b/externals/grill/pool/source/pool.cpp index 6b75b4c6..163cae0c 100644 --- a/externals/grill/pool/source/pool.cpp +++ b/externals/grill/pool/source/pool.cpp @@ -2,7 +2,7 @@ pool - hierarchical storage object for PD and Max/MSP -Copyright (c) 2002-2005 Thomas Grill +Copyright (c) 2002-2006 Thomas Grill (gr@grrrr.org) For information on usage and redistribution, and for a DISCLAIMER OF ALL WARRANTIES, see the file, "license.txt," in this distribution. diff --git a/externals/grill/pool/source/pool.h b/externals/grill/pool/source/pool.h index 5d251cd8..f69ad2ea 100644 --- a/externals/grill/pool/source/pool.h +++ b/externals/grill/pool/source/pool.h @@ -2,7 +2,7 @@ pool - hierarchical storage object for PD and Max/MSP -Copyright (c) 2002-2005 Thomas Grill +Copyright (c) 2002-2006 Thomas Grill (gr@grrrr.org) For information on usage and redistribution, and for a DISCLAIMER OF ALL WARRANTIES, see the file, "license.txt," in this distribution. @@ -128,6 +128,8 @@ public: pooldata(const S *s = NULL,I vcnt = 0,I dcnt = 0); ~pooldata(); + bool Private() const { return sym == NULL; } + V Push() { ++refs; } BL Pop() { return --refs > 0; } -- cgit v1.2.1