Salome HOME
Merge from rnv/geom_plugin_imp branch
[plugins/acisplugin.git] / src / ACISPlugin_OperationsCreator.cxx
diff --git a/src/ACISPlugin_OperationsCreator.cxx b/src/ACISPlugin_OperationsCreator.cxx
new file mode 100644 (file)
index 0000000..ce458f1
--- /dev/null
@@ -0,0 +1,71 @@
+// Copyright (C) 2014-2015  OPEN CASCADE
+//
+// 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
+//
+
+// internal includes
+#include "ACISPlugin_OperationsCreator.hxx"
+#include "ACISPlugin_IOperations_i.hh"
+#include "ACISPlugin_ExportDriver.hxx"
+#include "ACISPlugin_ImportDriver.hxx"
+#include "ACISPlugin_IECallBack.hxx"
+
+// KERNEL includes
+#include <Utils_ExceptHandlers.hxx>
+#include <utilities.h>
+
+// GEOM includes
+#include <GEOMImpl_IECallBack.hxx>
+
+// OCCT includes
+#include <TFunction_DriverTable.hxx>
+
+std::map <int, ACISPlugin_IOperations*> ACISPlugin_OperationsCreator::_mapOfOperations;
+
+ACISPlugin_OperationsCreator::ACISPlugin_OperationsCreator()
+{
+  // Register drivers
+  TFunction_DriverTable::Get()->AddDriver( ACISPlugin_ExportDriver::GetID(),
+                                           new ACISPlugin_ExportDriver() );
+  TFunction_DriverTable::Get()->AddDriver( ACISPlugin_ImportDriver::GetID(),
+                                           new ACISPlugin_ImportDriver() );
+  // Register callback
+  ACISPlugin_IECallBack* callback = new ACISPlugin_IECallBack();
+  GEOMImpl_IECallBack::Register( "ACIS", callback );
+}
+
+ACISPlugin_OperationsCreator::~ACISPlugin_OperationsCreator()
+{
+}
+
+GEOM_IOperations_i* ACISPlugin_OperationsCreator::Create( PortableServer::POA_ptr thePOA,
+                                                          int                     theStudyId,
+                                                          GEOM::GEOM_Gen_ptr      theEngine,
+                                                          ::GEOMImpl_Gen*         theGenImpl )
+{
+  Unexpect aCatch( SALOME_SalomeException );
+  MESSAGE( "ACISPlugin_OperationsCreator::Create" );
+  return new ACISPlugin_IOperations_i( thePOA, theEngine, get( theGenImpl, theStudyId ) );
+}
+
+ACISPlugin_IOperations* ACISPlugin_OperationsCreator::get( ::GEOMImpl_Gen* theGenImpl,
+                                                           int             theStudyId )
+{
+  if (_mapOfOperations.find( theStudyId ) == _mapOfOperations.end() )
+    _mapOfOperations[theStudyId] = new ACISPlugin_IOperations( theGenImpl, theStudyId );
+  return _mapOfOperations[theStudyId];
+}