Salome HOME
Correct boost headers variable
[modules/kernel.git] / src / SALOMEDS / SALOMEDS_UseCaseBuilder_i.hxx
index 796c803794533ccb4ee77c0b28c951f97a7b915d..901b7e2be34117388e0cf255dede3df1ee6f8d71 100644 (file)
@@ -1,53 +1,74 @@
-//  SALOME SALOMEDS : data structure of SALOME and sources of Salome data server 
+// Copyright (C) 2007-2020  CEA/DEN, EDF R&D, OPEN CASCADE
 //
-//  Copyright (C) 2003  CEA/DEN, EDF R&D
+// 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, or (at your option) any later version.
 //
+// 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_UseCaseBuilder_i.hxx
-//  Author : Yves FRICAUD
+//  Author : Sergey RUIN
 //  Module : SALOME
 
 #ifndef __SALOMEDS_USECaseBuilder_I_H__
 #define __SALOMEDS_USECaseBuilder_I_H__
 
+// std C++ headers
+#include <iostream>
+
 // IDL headers
 #include <SALOMEconfig.h>
 #include CORBA_SERVER_HEADER(SALOMEDS)
 #include CORBA_SERVER_HEADER(SALOMEDS_Attributes)
+#include <SALOME_GenericObj_i.hh>
 
-// Cascade headers
-#include <TDataStd_TreeNode.hxx>
-#include <TDocStd_Document.hxx>
+#include <stdio.h>
 
-class SALOMEDS_Study_i;
+#include "SALOMEDSImpl_UseCaseIterator.hxx"
+#include "SALOMEDSImpl_UseCaseBuilder.hxx"
 
-class SALOMEDS_UseCaseBuilder_i: public POA_SALOMEDS::UseCaseBuilder,
-                                public PortableServer::RefCountServantBase 
+class SALOMEDS_UseCaseBuilder_i: public virtual POA_SALOMEDS::UseCaseBuilder,
+                                 public virtual PortableServer::ServantBase,
+                                 public virtual SALOME::GenericObj_i
 {
-  SALOMEDS_UseCaseBuilder_i(); // Not implemented
-  void operator=(const SALOMEDS_UseCaseBuilder_i&); // Not implemented
-
 private:
-  Handle(TDataStd_TreeNode)     _root;
-  Handle(TDocStd_Document)      _doc;
-  SALOMEDS_Study_i*             _study;
+
+  CORBA::ORB_var               _orb;
+  SALOMEDSImpl_UseCaseBuilder* _impl;
 
 public:
-  SALOMEDS_UseCaseBuilder_i(SALOMEDS_Study_i* theStudy,
-                           const Handle(TDocStd_Document)& theDocument);
+
+  //! standard constructor  
+  SALOMEDS_UseCaseBuilder_i(SALOMEDSImpl_UseCaseBuilder* theDocument,
+                            CORBA::ORB_ptr);
   
+  //! standard destructor
   ~SALOMEDS_UseCaseBuilder_i();
-  
-  CORBA::ORB_var GetORB() const;
-  PortableServer::POA_var GetPOA() const;
 
+  virtual PortableServer::POA_ptr _default_POA();
+  
   virtual CORBA::Boolean Append(SALOMEDS::SObject_ptr theObject);
 
   virtual CORBA::Boolean Remove(SALOMEDS::SObject_ptr theObject);
 
   virtual CORBA::Boolean AppendTo(SALOMEDS::SObject_ptr theFather, SALOMEDS::SObject_ptr theObject);
 
+  virtual CORBA::Long GetIndexInFather(SALOMEDS::SObject_ptr theFather, SALOMEDS::SObject_ptr theObject);
+
   virtual CORBA::Boolean InsertBefore(SALOMEDS::SObject_ptr theFirst, SALOMEDS::SObject_ptr theNext);
 
   virtual CORBA::Boolean  SetCurrentObject(SALOMEDS::SObject_ptr theObject);
@@ -56,8 +77,14 @@ public:
 
   virtual CORBA::Boolean  HasChildren(SALOMEDS::SObject_ptr theObject);
 
+  virtual CORBA::Boolean  SortChildren(SALOMEDS::SObject_ptr theObject, CORBA::Boolean theAscendingOrder);
+
+  virtual SALOMEDS::SObject_ptr GetFather(SALOMEDS::SObject_ptr theObject);
+
   virtual CORBA::Boolean  IsUseCase(SALOMEDS::SObject_ptr theObject);
 
+  virtual CORBA::Boolean  IsUseCaseNode(SALOMEDS::SObject_ptr theObject);
+
   virtual CORBA::Boolean SetName(const char* theName);
 
   virtual SALOMEDS::SObject_ptr GetCurrentObject();