-// SALOME SALOMEDS : data structure of SALOME and sources of Salome data server
+// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
//
-// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
-// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
-//
-// This library is free software; you can redistribute it and/or
-// modify it under the terms of the GNU Lesser General Public
-// License as published by the Free Software Foundation; either
-// version 2.1 of the License.
-//
-// This library is distributed in the hope that it will be useful,
-// but WITHOUT ANY WARRANTY; without even the implied warranty of
-// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
-// Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public
-// License along with this library; if not, write to the Free Software
-// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-//
-// See http://www.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org
+// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
+// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License.
//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+
// File : SALOMEDS_AttributeTreeNode_i.cxx
-// Author : Yves FRICAUD
+// Author : Sergey RUIN
// Module : SALOME
-// $Header$
-
-#include <TDocStd_Document.hxx>
-#include <TDF_Tool.hxx>
-
+//
#include "SALOMEDS_AttributeTreeNode_i.hxx"
-
#include "utilities.h"
+#include "SALOMEDS.hxx"
-using namespace std;
-
-static Handle(TDataStd_TreeNode) GetNode(SALOMEDS::AttributeTreeNode_ptr value,
- const Handle(TDataStd_TreeNode)& aNode)
+static SALOMEDSImpl_AttributeTreeNode* GetNode(SALOMEDS::AttributeTreeNode_ptr value,
+ SALOMEDSImpl_AttributeTreeNode* aNode)
{
- Handle(TDataStd_TreeNode) aResult = new TDataStd_TreeNode;
- CORBA::String_var aString = CORBA::string_dup(value->Label());
- TDF_Label aLabel;
- TDF_Tool::Label(aNode->Label().Data(), TCollection_AsciiString(aString), aLabel, 0);
+ SALOMEDSImpl_AttributeTreeNode* aResult = NULL;
+ DF_Label aLabel = DF_Label::Label(aNode->Label(), value->Label());
if (aLabel.IsNull()) {
MESSAGE("SALOMEDS_AttributeTreeNode_i class: no such label")
MESSAGE("SALOMEDS_AttributeTreeNode_i class: no such label")
return aResult;
}
- if (!aLabel.FindAttribute(aNode->ID(), aResult)) {
+ if (!(aResult=(SALOMEDSImpl_AttributeTreeNode*)aLabel.FindAttribute(aNode->ID()))) {
MESSAGE("SALOMEDS_AttributeTreeNode_i class: no such attribute")
MESSAGE("SALOMEDS_AttributeTreeNode_i class: no such attribute")
}
return aResult;
}
-void SALOMEDS_AttributeTreeNode_i::SetFather(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::SetFather(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->SetFather(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->SetFather(GetNode(value, aNode));
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasFather() {
- return _myAttr->HasFather();
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasFather()
+{
+ SALOMEDS::Locker lock;
+ return dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->HasFather();
}
-SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetFather() {
- SALOMEDS_AttributeTreeNode_i* aTreeNode =
- new SALOMEDS_AttributeTreeNode_i(_myAttr->Father(),_mySObject);
- return aTreeNode->_this();
+SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetFather()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDS_AttributeTreeNode_i* aFather;
+ aFather = new SALOMEDS_AttributeTreeNode_i(dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->GetFather(), _orb);
+#ifndef WIN32
+ return aFather->POA_SALOMEDS::AttributeTreeNode::_this();
+#else
+ return aFather->AttributeTreeNode::_this();
+#endif
}
-void SALOMEDS_AttributeTreeNode_i::SetPrevious(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::SetPrevious(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->SetPrevious(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->SetPrevious(GetNode(value, aNode));
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasPrevious() {
- return _myAttr->HasPrevious();
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasPrevious()
+{
+ SALOMEDS::Locker lock;
+ return dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->HasPrevious();
}
-SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetPrevious() {
- SALOMEDS_AttributeTreeNode_i* aTreeNode =
- new SALOMEDS_AttributeTreeNode_i(_myAttr->Previous(),_mySObject);
- return aTreeNode->_this();
+SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetPrevious()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDS_AttributeTreeNode_i* aPrevious;
+ aPrevious=new SALOMEDS_AttributeTreeNode_i(dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->GetPrevious(), _orb);
+#ifndef WIN32
+ return aPrevious->POA_SALOMEDS::AttributeTreeNode::_this();
+#else
+ return aPrevious->AttributeTreeNode::_this();
+#endif
}
-void SALOMEDS_AttributeTreeNode_i::SetNext(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::SetNext(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->SetNext(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->SetNext(GetNode(value, aNode));
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasNext() {
- return _myAttr->HasNext();
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasNext()
+{
+ SALOMEDS::Locker lock;
+ return dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->HasNext();
}
-SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetNext() {
- SALOMEDS_AttributeTreeNode_i* aTreeNode =
- new SALOMEDS_AttributeTreeNode_i(_myAttr->Next(),_mySObject);
- return aTreeNode->_this();
+SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetNext()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDS_AttributeTreeNode_i* aNext;
+ aNext = new SALOMEDS_AttributeTreeNode_i(dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->GetNext(), _orb);
+#ifndef WIN32
+ return aNext->POA_SALOMEDS::AttributeTreeNode::_this();
+#else
+ return aNext->AttributeTreeNode::_this();
+#endif
}
-void SALOMEDS_AttributeTreeNode_i::SetFirst(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::SetFirst(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->SetFirst(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->SetFirst(GetNode(value, aNode));
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasFirst() {
- return _myAttr->HasFirst();
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::HasFirst()
+{
+ SALOMEDS::Locker lock;
+ return dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->HasFirst();
}
-SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetFirst() {
- SALOMEDS_AttributeTreeNode_i* aTreeNode =
- new SALOMEDS_AttributeTreeNode_i(_myAttr->First(),_mySObject);
- return aTreeNode->_this();
+SALOMEDS::AttributeTreeNode_ptr SALOMEDS_AttributeTreeNode_i::GetFirst()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDS_AttributeTreeNode_i* aFirst;
+ aFirst = new SALOMEDS_AttributeTreeNode_i(dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl)->GetFirst(), _orb);
+#ifndef WIN32
+ return aFirst->POA_SALOMEDS::AttributeTreeNode::_this();
+#else
+ return aFirst->AttributeTreeNode::_this();
+#endif
}
-void SALOMEDS_AttributeTreeNode_i::SetTreeID(const char* value) {
+void SALOMEDS_AttributeTreeNode_i::SetTreeID(const char* value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->SetTreeID(Standard_GUID(_myAttr->ID()));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->SetTreeID(value);
}
-char* SALOMEDS_AttributeTreeNode_i::GetTreeID() {
- char aGUID[40];
- _myAttr->ID().ToCString(aGUID);
- return CORBA::string_dup(aGUID);
+char* SALOMEDS_AttributeTreeNode_i::GetTreeID()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ return CORBA::String_var(CORBA::string_dup(aNode->ID().c_str()))._retn();
}
-void SALOMEDS_AttributeTreeNode_i::Append(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::Append(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->Append(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->Append(GetNode(value, aNode));
}
-void SALOMEDS_AttributeTreeNode_i::Prepend(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::Prepend(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->Prepend(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->Prepend(GetNode(value, aNode));
}
-void SALOMEDS_AttributeTreeNode_i::InsertBefore(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::InsertBefore(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->InsertBefore(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->InsertBefore(GetNode(value, aNode));
}
-void SALOMEDS_AttributeTreeNode_i::InsertAfter(SALOMEDS::AttributeTreeNode_ptr theValue) {
+void SALOMEDS_AttributeTreeNode_i::InsertAfter(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->InsertAfter(GetNode(theValue,_myAttr));
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->InsertAfter(GetNode(value, aNode));
}
-void SALOMEDS_AttributeTreeNode_i::Remove() {
+void SALOMEDS_AttributeTreeNode_i::Remove()
+{
+ SALOMEDS::Locker lock;
CheckLocked();
- _myAttr->Remove();
-}
-
-CORBA::Long SALOMEDS_AttributeTreeNode_i::Depth() {
- return _myAttr->Depth();
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ aNode->Remove();
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsRoot() {
- return _myAttr->IsRoot();
+CORBA::Long SALOMEDS_AttributeTreeNode_i::Depth()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ return aNode->Depth();
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsDescendant(SALOMEDS::AttributeTreeNode_ptr theValue) {
- return _myAttr->IsDescendant(GetNode(theValue,_myAttr));
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsRoot()
+{
+ SALOMEDS::Locker lock;
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ return aNode->IsRoot();
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsFather(SALOMEDS::AttributeTreeNode_ptr theValue) {
- return _myAttr->IsFather(GetNode(theValue,_myAttr));
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsDescendant(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ return aNode->IsDescendant(GetNode(value, aNode));
}
-CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsChild(SALOMEDS::AttributeTreeNode_ptr theValue) {
- return _myAttr->IsChild(GetNode(theValue,_myAttr));
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsFather(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ return aNode->IsFather(GetNode(value, aNode));
}
-char* SALOMEDS_AttributeTreeNode_i::Label() {
- TCollection_AsciiString aLabelName;
- TDF_Tool::Entry(_myAttr->Label(),aLabelName);
- return CORBA::string_dup(aLabelName.ToCString());
+CORBA::Boolean SALOMEDS_AttributeTreeNode_i::IsChild(SALOMEDS::AttributeTreeNode_ptr value)
+{
+ SALOMEDS::Locker lock;
+ SALOMEDSImpl_AttributeTreeNode* aNode = dynamic_cast<SALOMEDSImpl_AttributeTreeNode*>(_impl);
+ return aNode->IsChild(GetNode(value, aNode));
}
-char* SALOMEDS_AttributeTreeNode_i::Store() {
- char* aStr[4];
-
- if (HasFather()) aStr[0] = GetFather()->Label(); else aStr[0] = "!";
- if (HasPrevious()) aStr[1] = GetPrevious()->Label(); else aStr[1] = "!";
- if (HasNext()) aStr[2] = GetNext()->Label(); else aStr[2] = "!";
- if (HasFirst()) aStr[3] = GetFirst()->Label(); else aStr[3] = "!";
-
- int aLength = 4;
- aLength += strlen(aStr[0]) + strlen(aStr[1]) + strlen(aStr[2]) + strlen(aStr[3]);
- CORBA::String_var aResult = new char[aLength];
- sprintf(aResult, "%s %s %s %s", aStr[0], aStr[1], aStr[2], aStr[3]);
- return aResult._retn();
+char* SALOMEDS_AttributeTreeNode_i::Label()
+{
+ SALOMEDS::Locker lock;
+ return CORBA::String_var(CORBA::string_dup(_impl->Label().Entry().c_str()))._retn();
}
-void SALOMEDS_AttributeTreeNode_i::Restore(const char* value) {
- Handle(TDataStd_TreeNode) aNode = Handle(TDataStd_TreeNode)::DownCast(_myAttr);
- Handle(TDF_Data) DF = TDocStd_Document::Get(_myAttr->Label())->GetData();
-
- char* aCopy = strdup(value);
- char* adr = strtok(aCopy, " ");
-
- TDF_Label aLabel;
- Handle(TDataStd_TreeNode) aDepNode;
-
- if (adr && adr[0] != '!') {
- TDF_Tool::Label(DF, adr, aLabel, 1);
- if (!aLabel.FindAttribute(aNode->ID(), aDepNode)) aDepNode = TDataStd_TreeNode::Set(aLabel, aNode->ID());
- aNode->SetFather(aDepNode);
- }
-
- adr = strtok(NULL, " ");
- if (adr && adr[0] != '!') {
- TDF_Tool::Label(DF, adr, aLabel, 1);
- if (!aLabel.FindAttribute(aNode->ID(), aDepNode)) aDepNode = TDataStd_TreeNode::Set(aLabel, aNode->ID());
- aNode->SetPrevious(aDepNode);
- }
-
- adr = strtok(NULL, " ");
- if (adr && adr[0] != '!') {
- TDF_Tool::Label(DF, adr, aLabel, 1);
- if (!aLabel.FindAttribute(aNode->ID(), aDepNode)) aDepNode = TDataStd_TreeNode::Set(aLabel, aNode->ID());
- aNode->SetNext(aDepNode);
- }
-
- adr = strtok(NULL, " ");
- if (adr && adr[0] != '!') {
- TDF_Tool::Label(DF, adr, aLabel, 1);
- if (!aLabel.FindAttribute(aNode->ID(), aDepNode)) aDepNode = TDataStd_TreeNode::Set(aLabel, aNode->ID());
- aNode->SetFirst(aDepNode);
- }
-}