X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FSMESH_I%2FSMESH_Hypothesis_i.hxx;h=df89d82c818e9464c60602120bedb374815fff63;hp=9277426d344c65fb3be440318dbbdb3ea99cace1;hb=9d28d73b09e96b23cf9937afa17474f98508df18;hpb=4791f5b30ea7a9c1247aa551750dc71cb83b99aa diff --git a/src/SMESH_I/SMESH_Hypothesis_i.hxx b/src/SMESH_I/SMESH_Hypothesis_i.hxx index 9277426d3..df89d82c8 100644 --- a/src/SMESH_I/SMESH_Hypothesis_i.hxx +++ b/src/SMESH_I/SMESH_Hypothesis_i.hxx @@ -32,23 +32,84 @@ #include #include CORBA_SERVER_HEADER(SMESH_Hypothesis) -class SMESH_Gen; -class SMESH_Hypothesis; +#include "SMESH_Hypothesis.hxx" +#include "SALOME_GenericObj_i.hh" +#include "SMESH_Gen.hxx" + +// ====================================================== +// Generic hypothesis +// ====================================================== class SMESH_Hypothesis_i: - public POA_SMESH::SMESH_Hypothesis + public virtual POA_SMESH::SMESH_Hypothesis, + public virtual SALOME::GenericObj_i { public: - SMESH_Hypothesis_i(); + // Constructor : placed in protected section to prohibit creation of generic class instance + SMESH_Hypothesis_i( PortableServer::POA_ptr thePOA ); + +public: + // Destructor virtual ~SMESH_Hypothesis_i(); + // Get type name of hypothesis char* GetName(); + + // Get plugin library name of hypothesis + char* GetLibName(); + + // Set plugin library name of hypothesis + void SetLibName( const char* theLibName ); + + // Get unique id of hypothesis CORBA::Long GetId(); + // Get implementation + ::SMESH_Hypothesis* GetImpl(); + + // _CS_gbo_ Activate the object using the POA + void Activate(); + + // Persistence + virtual char* SaveTo(); + virtual void LoadFrom( const char* theStream ); + protected: - ::SMESH_Hypothesis* _baseImpl; - ::SMESH_Gen* _genImpl; - int _id; + ::SMESH_Hypothesis* myBaseImpl; // base hypothesis implementation + + // _CS_gbo_070505 To keep the reference and delayed the activation + // in the methode Activate(). + PortableServer::POA_ptr myPOA; +}; + +// ====================================================== +// Generic hypothesis creator +// ====================================================== +class GenericHypothesisCreator_i +{ +public: + // Create a hypothesis + virtual SMESH_Hypothesis_i* Create(PortableServer::POA_ptr thePOA, + int theStudyId, + ::SMESH_Gen* theGenImpl) = 0; +}; + +//============================================================================= +// +// Specific Hypothesis Creators are generated with a template which inherits a +// generic hypothesis creator. Each creator returns an hypothesis of the type +// given in the template. +// +//============================================================================= +template class HypothesisCreator_i: public GenericHypothesisCreator_i +{ +public: + virtual SMESH_Hypothesis_i* Create (PortableServer::POA_ptr thePOA, + int theStudyId, + ::SMESH_Gen* theGenImpl) + { + return new T (thePOA, theStudyId, theGenImpl); + }; }; #endif