X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIOTreeNode.cpp;h=e14bc8450b8fe6dd5514f5283e921e4f679c6a5b;hb=34d2d6b1860321978fd19668bbf6fd0606ac1e80;hp=6814203c004a77816090003b0bbeffde5ed4ab10;hpb=fcfe92562365cb738cf919d095d2f8d3608ec389;p=creaImageIO.git diff --git a/src2/creaImageIOTreeNode.cpp b/src2/creaImageIOTreeNode.cpp index 6814203..e14bc84 100644 --- a/src2/creaImageIOTreeNode.cpp +++ b/src2/creaImageIOTreeNode.cpp @@ -2,7 +2,10 @@ #include #include #include - +#include +#ifdef _DEBUG +#define new DEBUG_NEW +#endif namespace creaImageIO { namespace tree @@ -11,21 +14,20 @@ namespace creaImageIO //============================================================= /// Ctor with parent Node::Node(Node* parent) - : mParent(parent), - mData(0), + : mParent(parent),//mData(0), mChildrenLoaded(false) { if (parent) { - GimmickMessage(5,"Default Node constructor (level "<GetChildrenList().push_back(this); InitializeAttributeMap(); + parent->GetChildrenList().push_back(this); } else { - GimmickMessage(5,"Default Node constructor without parent" + GimmickDebugMessage(6,"Default Node constructor without parent" << std::endl); } } @@ -34,12 +36,12 @@ namespace creaImageIO //============================================================= /// Ctor with parent and attributes map Node::Node(Node* parent, const AttributeMapType& attr) - : mParent(parent), - mData(0), + : mParent(parent),//mData(0), mChildrenLoaded(false) { - GimmickMessage(5,"Node constructor (level "<second; } - GimmickMessage(5,"Setting attribute '"<GetName()<<"' = '" + GimmickDebugMessage(6,"Setting attribute '"<GetName()<<"' = '" <GetKey(), v ); } @@ -69,18 +71,14 @@ namespace creaImageIO //============================================================= Node::~Node() { - GimmickMessage(5,"Node destructor" + GimmickDebugMessage(6,"Node destructor" << std::endl); ChildrenListType::iterator i; for (i=GetChildrenList().begin(); i!=GetChildrenList().end(); i++) { delete *i; } - if (mData) - { - delete mData; - mData = 0; - } + } //============================================================= @@ -106,10 +104,31 @@ namespace creaImageIO { return GetTree()->GetLevelDescriptor(GetLevel()); } + + //============================================================= + + //============================================================= + /// Returns the attribute descriptor of the passed parameter + const AttributeDescriptor& Node::GetAttributeDescriptor(const std::string& k)const + { + LevelDescriptor::AttributeDescriptorListType::const_iterator a; + for (a = GetTree()->GetAttributeDescriptorList(GetLevel()).begin(); + a!= GetTree()->GetAttributeDescriptorList(GetLevel()).end(); + ++a) + { + + if(a->GetKey()==k) + { + return *a; + } + + } + return *a; + } //============================================================= //============================================================= - void Node::RemoveChildrenFromList(Node* node) + int Node::RemoveChildrenFromList(Node* node) { ChildrenListType::iterator i = find(GetChildrenList().begin(), GetChildrenList().end(), @@ -118,6 +137,7 @@ namespace creaImageIO { GetChildrenList().erase(i); } + return GetChildrenList().size(); } //============================================================= @@ -156,7 +176,7 @@ namespace creaImageIO //============================================================= bool Node::Matches( const AttributeMapType& m ) const { - GimmickMessage(2,"'"<& id = GetLevelDescriptor().GetIdentifierList(); std::vector::const_iterator i; @@ -164,10 +184,10 @@ namespace creaImageIO { if (mAttributeMap.find(*i)->second != m.find(*i)->second ) { - GimmickMessage(2,"IDENTIFIER '"<<*i<<"' values do not match"<Print(); + (*j)->Print(); } } //============================================================= @@ -198,7 +218,7 @@ namespace creaImageIO std::vector::const_iterator i; for (i = label.begin(); i != label.end(); ) { - GimmickMessage(3,"LABEL '"<<*i<<"'"<