Salome HOME
Update copyright information
[plugins/netgenplugin.git] / src / NETGENPlugin / NETGENPlugin_SimpleHypothesis_3D_i.cxx
1 //  Copyright (C) 2007-2008  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 //  Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 //  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 //  This library is free software; you can redistribute it and/or
7 //  modify it under the terms of the GNU Lesser General Public
8 //  License as published by the Free Software Foundation; either
9 //  version 2.1 of the License.
10 //
11 //  This library is distributed in the hope that it will be useful,
12 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
13 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 //  Lesser General Public License for more details.
15 //
16 //  You should have received a copy of the GNU Lesser General Public
17 //  License along with this library; if not, write to the Free Software
18 //  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19 //
20 //  See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 //  NETGENPlugin : C++ implementation
23 // File      : NETGENPlugin_SimpleHypothesis_3D_i.cxx
24 // Author    : Edward AGAPOV
25 // Project   : SALOME
26 //=============================================================================
27 //
28 #include "NETGENPlugin_SimpleHypothesis_3D_i.hxx"
29 #include "NETGENPlugin_SimpleHypothesis_3D.hxx"
30
31 #include <SMESH_Gen.hxx>
32 #include <SMESH_PythonDump.hxx>
33
34 #include <Utils_CorbaException.hxx>
35 #include <utilities.h>
36
37 using namespace std;
38
39 //=============================================================================
40 /*!
41  *  NETGENPlugin_SimpleHypothesis_3D_i::NETGENPlugin_SimpleHypothesis_3D_i
42  *
43  *  Constructor
44  */
45 //=============================================================================
46 NETGENPlugin_SimpleHypothesis_3D_i::
47 NETGENPlugin_SimpleHypothesis_3D_i (PortableServer::POA_ptr thePOA,
48                                     int                     theStudyId,
49                                     ::SMESH_Gen*            theGenImpl)
50   : SALOME::GenericObj_i( thePOA ),
51     SMESH_Hypothesis_i( thePOA ),
52     NETGENPlugin_SimpleHypothesis_2D_i( thePOA,theStudyId,theGenImpl )
53 {
54   MESSAGE( "NETGENPlugin_SimpleHypothesis_3D_i::NETGENPlugin_SimpleHypothesis_3D_i" );
55   if ( myBaseImpl )
56     delete myBaseImpl;
57   myBaseImpl = new ::NETGENPlugin_SimpleHypothesis_3D (theGenImpl->GetANewId(),
58                                                        theStudyId,
59                                                        theGenImpl);
60 }
61
62 //=============================================================================
63 /*!
64  *  NETGENPlugin_SimpleHypothesis_3D_i::~NETGENPlugin_SimpleHypothesis_3D_i
65  *
66  *  Destructor
67  */
68 //=============================================================================
69 NETGENPlugin_SimpleHypothesis_3D_i::~NETGENPlugin_SimpleHypothesis_3D_i()
70 {
71   MESSAGE( "NETGENPlugin_SimpleHypothesis_3D_i::~NETGENPlugin_SimpleHypothesis_3D_i" );
72 }
73
74 //=============================================================================
75 /*!
76  *  NETGENPlugin_SimpleHypothesis_3D_i::LengthFromFaces()
77  */
78 //=============================================================================
79 void NETGENPlugin_SimpleHypothesis_3D_i::LengthFromFaces()
80 {
81   MESSAGE("NETGENPlugin_SimpleHypothesis_3D_i::LengthFromFaces");
82   ASSERT(myBaseImpl);
83   this->GetImpl()->LengthFromFaces();
84   SMESH::TPythonDump() << _this() << ".LengthFromFaces()";
85 }
86
87 //=============================================================================
88 /*!
89  *  NETGENPlugin_SimpleHypothesis_3D_i::SetMaxElementVolume()
90  */
91 //=============================================================================
92 void NETGENPlugin_SimpleHypothesis_3D_i::SetMaxElementVolume(CORBA::Double value)
93 {
94   MESSAGE("NETGENPlugin_SimpleHypothesis_3D_i::SetMaxElementVolume");
95   ASSERT(myBaseImpl);
96   this->GetImpl()->SetMaxElementVolume(value);
97   SMESH::TPythonDump() << _this() << ".SetMaxElementVolume( " << value << " )";
98 }
99
100
101 //=============================================================================
102 /*!
103  *  NETGENPlugin_SimpleHypothesis_3D_i::GetMaxElementVolume()
104  */
105 //=============================================================================
106 CORBA::Double NETGENPlugin_SimpleHypothesis_3D_i::GetMaxElementVolume()
107 {
108   MESSAGE("NETGENPlugin_SimpleHypothesis_3D_i::GetMaxElementVolume");
109   ASSERT(myBaseImpl);
110   return this->GetImpl()->GetMaxElementVolume();
111 }
112 //=============================================================================
113 /*!
114  *  NETGENPlugin_SimpleHypothesis_3D_i::GetImpl
115  */
116 //=============================================================================
117 ::NETGENPlugin_SimpleHypothesis_3D* NETGENPlugin_SimpleHypothesis_3D_i::GetImpl()
118 {
119   MESSAGE("NETGENPlugin_SimpleHypothesis_3D_i::GetImpl");
120   return (::NETGENPlugin_SimpleHypothesis_3D*)myBaseImpl;
121 }
122
123 //================================================================================
124 /*!
125  * \brief Verify whether hypothesis supports given entity type 
126   * \param type - dimension (see SMESH::Dimension enumeration)
127   * \retval CORBA::Boolean - TRUE if dimension is supported, FALSE otherwise
128  * 
129  * Verify whether hypothesis supports given entity type (see SMESH::Dimension enumeration)
130  */
131 //================================================================================  
132 CORBA::Boolean NETGENPlugin_SimpleHypothesis_3D_i::IsDimSupported( SMESH::Dimension type )
133 {
134   return type == SMESH::DIM_3D;
135 }