X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src2%2FcreaImageIOTreeNode.cpp;h=faa0bf00cad7982493c084aeb17bce08a0464ee4;hb=cc5a912f64e8de1f90d9ef0956633515a46d31ae;hp=4335dfe05b365e30de98d43ee5c4737e014854fd;hpb=f08880c40f6304be640c7f8702bbbe96f8d50b40;p=creaImageIO.git diff --git a/src2/creaImageIOTreeNode.cpp b/src2/creaImageIOTreeNode.cpp index 4335dfe..faa0bf0 100644 --- a/src2/creaImageIOTreeNode.cpp +++ b/src2/creaImageIOTreeNode.cpp @@ -1,7 +1,6 @@ #include #include #include -#include #include namespace creaImageIO @@ -10,7 +9,7 @@ namespace creaImageIO { //============================================================= - /// Ctor with parent + /// Ctor with parent Why does it enter once while charging? Node::Node(Node* parent) : mParent(parent), mData(0), @@ -18,15 +17,15 @@ namespace creaImageIO { 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); } } @@ -39,7 +38,7 @@ namespace creaImageIO mData(0), mChildrenLoaded(false) { - GimmickMessage(5,"Node constructor (level "<second; } - GimmickMessage(5,"Setting attribute '"<GetName()<<"' = '" + GimmickDebugMessage(6,"Setting attribute '"<GetName()<<"' = '" <GetKey(), v ); } @@ -70,7 +69,7 @@ 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++) @@ -107,10 +106,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(), @@ -119,6 +139,7 @@ namespace creaImageIO { GetChildrenList().erase(i); } + return GetChildrenList().size(); } //============================================================= @@ -157,7 +178,7 @@ namespace creaImageIO //============================================================= bool Node::Matches( const AttributeMapType& m ) const { - GimmickMessage(2,"'"<& id = GetLevelDescriptor().GetIdentifierList(); std::vector::const_iterator i; @@ -165,10 +186,10 @@ namespace creaImageIO { if (mAttributeMap.find(*i)->second != m.find(*i)->second ) { - GimmickMessage(2,"IDENTIFIER '"<<*i<<"' values do not match"<Print(); + (*j)->Print(); } } //============================================================= @@ -199,7 +220,7 @@ namespace creaImageIO std::vector::const_iterator i; for (i = label.begin(); i != label.end(); ) { - GimmickMessage(3,"LABEL '"<<*i<<"'"<