Salome HOME
SMH: Preparation version 3.0.0 - merge (HEAD+POLYWORK)
[modules/smesh.git] / src / SMESHGUI / SMESHGUI_Utils.h
index ab468bf32e2713ea9632ac4def9771df4fa23c98..15009ab9540167f0d7361434d8ab86768e7cee77 100644 (file)
@@ -1,67 +1,96 @@
 //  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 
+//  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
 
 #ifndef SMESHGUI_Utils_HeaderFile
 #define SMESHGUI_Utils_HeaderFile
 
+#include <CORBA.h>
+
+#include "SALOMEDSClient_definitions.hxx"
 #include "SALOME_InteractiveObject.hxx"
+#include "SalomeApp_DataOwner.h"
 
 class QString;
 
-class QAD_Study;
-class QAD_StudyFrame;
-class SALOME_Selection;
+class SUIT_ViewWindow;
+class SUIT_Desktop;
+class SUIT_Study;
+
+class CAM_Module;
 
-#include "SALOMEconfig.h"
-#include CORBA_CLIENT_HEADER(SALOMEDS)
+class SALOMEDSClient_Study;
+class SALOMEDSClient_SObject;
 
+class SalomeApp_Study;
+class SalomeApp_Module;
+class SalomeApp_SelectionMgr;
 
-namespace SMESH{
+namespace SMESH {
 
-  QAD_Study* GetActiveStudy();
+  SUIT_Desktop*
+  GetDesktop(const CAM_Module* theModule);
 
-  QAD_StudyFrame* GetActiveStudyFrame();
+  SalomeApp_SelectionMgr*
+  GetSelectionMgr(const SalomeApp_Module* theModule);
 
-  SALOMEDS::Study_var GetActiveStudyDocument();
+  SalomeApp_Study*
+  GetAppStudy(const CAM_Module* theModule);
 
-  SALOMEDS::SObject_var FindSObject(CORBA::Object_ptr theObject);
+  _PTR(Study)
+  GetCStudy(const SalomeApp_Study* theStudy);
 
+  CORBA::Object_var DataOwnerToObject(const SalomeApp_DataOwnerPtr& theOwner);
 
-  void SetName(SALOMEDS::SObject_ptr theSObject, const char* theName);
-  void SetValue(SALOMEDS::SObject_ptr theSObject, const char* theValue);
+  template<class TInterface> typename TInterface::_var_type
+    DataOwnerToInterface(const SalomeApp_DataOwnerPtr& theDataOwner)
+    {
+      CORBA::Object_var anObj = DataOwnerToObject(theDataOwner);
+      if(!CORBA::is_nil(anObj))
+       return TInterface::_narrow(anObj);
+      return TInterface::_nil();
+    }
 
 
-  CORBA::Object_var SObjectToObject(SALOMEDS::SObject_ptr theSObject,
-                                   SALOMEDS::Study_ptr theStudy);
-  
-  CORBA::Object_var SObjectToObject(SALOMEDS::SObject_ptr theSObject);
-  
+  SUIT_Study* GetActiveStudy();
+
+  SUIT_ViewWindow* GetActiveWindow();
+
+  _PTR(Study) GetActiveStudyDocument();
+
+  _PTR(SObject) FindSObject(CORBA::Object_ptr theObject);
+
+  void SetName  (_PTR(SObject) theSObject, const char* theName);
+  void SetValue (_PTR(SObject) theSObject, const char* theValue);
+
+  CORBA::Object_var SObjectToObject (_PTR(SObject) theSObject,
+                                    _PTR(Study) theStudy);
+
+  CORBA::Object_var SObjectToObject(_PTR(SObject) theSObject);
 
   template<class TInterface> typename TInterface::_var_type
-    SObjectToInterface(SALOMEDS::SObject_ptr theSObject)
+    SObjectToInterface(_PTR(SObject) theSObject)
     {
       CORBA::Object_var anObj = SObjectToObject(theSObject);
       if(!CORBA::is_nil(anObj))
        return TInterface::_narrow(anObj);
       return TInterface::_nil();
     }
-  
 
   CORBA::Object_var IObjectToObject(const Handle(SALOME_InteractiveObject)& theIO);
 
@@ -73,7 +102,6 @@ namespace SMESH{
        return TInterface::_narrow(anObj);
       return TInterface::_nil();
     }
-  
 
   CORBA::Object_var IORToObject(const char* theIOR);
 
@@ -85,15 +113,14 @@ namespace SMESH{
        return TInterface::_narrow(anObj);
       return TInterface::_nil();
     }
-  
 
-  int GetNameOfSelectedIObjects(SALOME_Selection* theSel, QString& theName);
+  int GetNameOfSelectedIObjects (SalomeApp_SelectionMgr*, QString& theName);
 
-  SALOMEDS::SObject_var GetMeshOrSubmesh(SALOMEDS::SObject_ptr theSObject);
+  _PTR(SObject) GetMeshOrSubmesh (_PTR(SObject) theSObject);
 
-  void ModifiedMesh(SALOMEDS::SObject_ptr theSObject, bool theIsRight);
+  void ModifiedMesh (_PTR(SObject) theSObject, bool theIsRight);
 
+//  void UpdateObjBrowser (bool);
 }
 
-
 #endif