-// Copyright (C) 2007-2015 CEA/DEN, EDF R&D, OPEN CASCADE
+// Copyright (C) 2007-2023 CEA/DEN, EDF R&D, OPEN CASCADE
//
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
//=============================================================================
NETGENPlugin_Hypothesis_i::
NETGENPlugin_Hypothesis_i (PortableServer::POA_ptr thePOA,
- int theStudyId,
::SMESH_Gen* theGenImpl)
- : SALOME::GenericObj_i( thePOA ),
+ : SALOME::GenericObj_i( thePOA ),
SMESH_Hypothesis_i( thePOA ),
mySetMethodFlags(0)
{
- MESSAGE( "NETGENPlugin_Hypothesis_i::NETGENPlugin_Hypothesis_i" );
myBaseImpl = new ::NETGENPlugin_Hypothesis (theGenImpl->GetANewId(),
- theStudyId,
theGenImpl);
}
//=============================================================================
NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i()
{
- MESSAGE( "NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i" );
}
//=============================================================================
//=============================================================================
+void NETGENPlugin_Hypothesis_i::SetChordalErrorEnabled(CORBA::Boolean theValue)
+{
+ if ( isToSetParameter( GetChordalErrorEnabled(), theValue, METH_SetChordalErrorEnabled ))
+ {
+ this->GetImpl()->SetChordalErrorEnabled(theValue);
+ SMESH::TPythonDump() << _this() << ".SetChordalErrorEnabled( " << theValue << " )";
+ }
+}
+
+CORBA::Boolean NETGENPlugin_Hypothesis_i::GetChordalErrorEnabled()
+{
+ return GetImpl()->GetChordalErrorEnabled();
+}
+
+void NETGENPlugin_Hypothesis_i::SetChordalError(CORBA::Double theValue)
+{
+ if ( isToSetParameter( GetChordalError(), theValue, METH_SetChordalError ))
+ {
+ this->GetImpl()->SetChordalError(theValue);
+ SMESH::TPythonDump() << _this() << ".SetChordalError( " << SMESH::TVar(theValue) << " )";
+ }
+}
+
+CORBA::Double NETGENPlugin_Hypothesis_i::GetChordalError()
+{
+ return GetImpl()->GetChordalError();
+}
+
+//=============================================================================
+
void NETGENPlugin_Hypothesis_i::SetLocalSizeOnShape(GEOM::GEOM_Object_ptr GeomObj,
CORBA::Double localSize)
- throw (SALOME::SALOME_Exception)
{
string entry;
entry = GeomObj->GetStudyEntry();
NETGENPlugin::string_array_var result = new NETGENPlugin::string_array();
const ::NETGENPlugin_Hypothesis::TLocalSize localSizes =
this->GetImpl()->GetLocalSizesAndEntries();
- result->length(localSizes.size());
+ result->length((CORBA::ULong) localSizes.size());
::NETGENPlugin_Hypothesis::TLocalSize::const_iterator it = localSizes.begin();
for (int i=0 ; it != localSizes.end() ; i++, it++)
{
void NETGENPlugin_Hypothesis_i::UnsetLocalSizeOnEntry(const char* entry)
{
this->GetImpl()->UnsetLocalSizeOnEntry(entry);
- SMESH::TPythonDump() << _this() << ".UnsetLocalSizeOnEntry(" << entry << ")";
+ SMESH::TPythonDump() << _this() << ".UnsetLocalSizeOnEntry(\"" << entry << "\")";
+}
+
+//=============================================================================
+
+void NETGENPlugin_Hypothesis_i::SetMeshSizeFile(const char* fileName)
+{
+ if ( GetImpl()->GetMeshSizeFile() != fileName )
+ {
+ GetImpl()->SetMeshSizeFile( fileName );
+ SMESH::TPythonDump() << _this() << ".SetMeshSizeFile( '" << fileName << "' )";
+ }
+}
+
+//=============================================================================
+
+char* NETGENPlugin_Hypothesis_i::GetMeshSizeFile()
+{
+ return CORBA::string_dup( GetImpl()->GetMeshSizeFile().c_str() );
}
//=============================================================================
return this->GetImpl()->GetFuseEdges();
}
+//=======================================================================
+//function : SetNbSurfOptSteps
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetNbSurfOptSteps(CORBA::Short nb )
+{
+ if ( GetNbSurfOptSteps() != nb )
+ {
+ this->GetImpl()->SetNbSurfOptSteps( nb );
+ SMESH::TPythonDump() << _this() << ".SetNbSurfOptSteps( " << SMESH::TVar(nb) << " )";
+ }
+}
+
+//=======================================================================
+//function : GetNbSurfOptSteps
+//purpose :
+//=======================================================================
+
+CORBA::Short NETGENPlugin_Hypothesis_i::GetNbSurfOptSteps()
+{
+ return (CORBA::Short) GetImpl()->GetNbSurfOptSteps();
+}
+
+//=======================================================================
+//function : SetNbVolOptSteps
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetNbVolOptSteps(CORBA::Short nb )
+{
+ if ( GetNbVolOptSteps() != nb )
+ {
+ this->GetImpl()->SetNbVolOptSteps( nb );
+ SMESH::TPythonDump() << _this() << ".SetNbVolOptSteps( " << SMESH::TVar(nb) << " )";
+ }
+
+}
+
+//=======================================================================
+//function : GetNbVolOptSteps
+//purpose :
+//=======================================================================
+
+CORBA::Short NETGENPlugin_Hypothesis_i::GetNbVolOptSteps()
+{
+ return (CORBA::Short) GetImpl()->GetNbVolOptSteps();
+}
+
+//=======================================================================
+//function : SetElemSizeWeight
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetElemSizeWeight(CORBA::Double size )
+{
+ if ( GetElemSizeWeight() != size )
+ {
+ this->GetImpl()->SetElemSizeWeight( size );
+ SMESH::TPythonDump() << _this() << ".SetElemSizeWeight( " << SMESH::TVar(size) << " )";
+ }
+}
+
+//=======================================================================
+//function : GetElemSizeWeight
+//purpose :
+//=======================================================================
+
+CORBA::Double NETGENPlugin_Hypothesis_i::GetElemSizeWeight()
+{
+ return GetImpl()->GetElemSizeWeight();
+}
+
+//=======================================================================
+//function : SetWorstElemMeasure
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetWorstElemMeasure(CORBA::Short val )
+{
+ if ( GetWorstElemMeasure() != val )
+ {
+ this->GetImpl()->SetWorstElemMeasure( val );
+ SMESH::TPythonDump() << _this() << ".SetWorstElemMeasure( " << SMESH::TVar(val) << " )";
+ }
+}
+
+//=======================================================================
+//function : GetWorstElemMeasure
+//purpose :
+//=======================================================================
+
+CORBA::Short NETGENPlugin_Hypothesis_i::GetWorstElemMeasure()
+{
+ return (CORBA::Short) GetImpl()->GetWorstElemMeasure();
+}
+
+//=======================================================================
+//function : SetNbThreads
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetNbThreads(CORBA::Short val )
+{
+ if ( GetNbThreads() != val )
+ {
+ this->GetImpl()->SetNbThreads( val );
+ SMESH::TPythonDump() << _this() << ".SetNbThreads( " << SMESH::TVar(val) << " )";
+ }
+}
+
+//=======================================================================
+//function : GetNbThreads
+//purpose :
+//=======================================================================
+
+CORBA::Short NETGENPlugin_Hypothesis_i::GetNbThreads()
+{
+ return (CORBA::Short) GetImpl()->GetNbThreads();
+}
+
+//=======================================================================
+//function : SetUseDelauney
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetUseDelauney(CORBA::Boolean toUse)
+{
+ if ( GetUseDelauney() != toUse )
+ {
+ this->GetImpl()->SetUseDelauney( toUse );
+ SMESH::TPythonDump() << _this() << ".SetUseDelauney( " << toUse << " )";
+ }
+}
+
+//=======================================================================
+//function : GetUseDelauney
+//purpose :
+//=======================================================================
+
+CORBA::Boolean NETGENPlugin_Hypothesis_i::GetUseDelauney()
+{
+ return GetImpl()->GetUseDelauney();
+}
+
+//=======================================================================
+//function : SetCheckOverlapping
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetCheckOverlapping(CORBA::Boolean toCheck )
+{
+ if ( GetCheckOverlapping() != toCheck )
+ {
+ this->GetImpl()->SetCheckOverlapping( toCheck );
+ SMESH::TPythonDump() << _this() << ".SetCheckOverlapping( " << toCheck << " )";
+ }
+}
+
+//=======================================================================
+//function : GetCheckOverlapping
+//purpose :
+//=======================================================================
+
+CORBA::Boolean NETGENPlugin_Hypothesis_i::GetCheckOverlapping()
+{
+ return GetImpl()->GetCheckOverlapping();
+}
+
+//=======================================================================
+//function : SetCheckChartBoundary
+//purpose :
+//=======================================================================
+
+void NETGENPlugin_Hypothesis_i::SetCheckChartBoundary(CORBA::Boolean toCheck )
+{
+ if ( GetCheckChartBoundary() != toCheck )
+ {
+ this->GetImpl()->SetCheckChartBoundary( toCheck );
+ SMESH::TPythonDump() << _this() << ".SetCheckChartBoundary( " << toCheck << " )";
+ }
+}
+
+//=======================================================================
+//function : GetCheckChartBoundary
+//purpose : Get implementation
+//=======================================================================
+
+CORBA::Boolean NETGENPlugin_Hypothesis_i::GetCheckChartBoundary()
+{
+ return GetImpl()->GetCheckChartBoundary();
+}
+
//=============================================================================
/*!
* NETGENPlugin_Hypothesis_i::GetImpl
//================================================================================
/*!
- * \brief Verify whether hypothesis supports given entity type
+ * \brief Verify whether hypothesis supports given entity type
* \param type - dimension (see SMESH::Dimension enumeration)
* \retval CORBA::Boolean - TRUE if dimension is supported, FALSE otherwise
- *
+ *
* Verify whether hypothesis supports given entity type (see SMESH::Dimension enumeration)
*/
-//================================================================================
+//================================================================================
CORBA::Boolean NETGENPlugin_Hypothesis_i::IsDimSupported( SMESH::Dimension type )
{
return type == SMESH::DIM_3D;
}
return "";
}
+
+//================================================================================
+/*!
+ * \brief Return geometry this hypothesis depends on. Return false if there is no geometry parameter
+ */
+//================================================================================
+
+bool
+NETGENPlugin_Hypothesis_i::getObjectsDependOn( std::vector< std::string > & entryArray,
+ std::vector< int > & /*subIDArray*/ ) const
+{
+ typedef ::NETGENPlugin_Hypothesis THyp;
+
+ const THyp* h = static_cast< ::NETGENPlugin_Hypothesis* >( myBaseImpl );
+ const THyp::TLocalSize& ls = h->GetLocalSizesAndEntries();
+
+ THyp::TLocalSize::const_iterator entry2size = ls.cbegin();
+ for ( ; entry2size != ls.cend(); ++entry2size )
+ entryArray.push_back( entry2size->first );
+
+ return true;
+}
+
+//================================================================================
+/*!
+ * \brief Set new geometry instead of that returned by getObjectsDependOn()
+ */
+//================================================================================
+
+bool
+NETGENPlugin_Hypothesis_i::setObjectsDependOn( std::vector< std::string > & entryArray,
+ std::vector< int > & /*subIDArray*/ )
+{
+ typedef ::NETGENPlugin_Hypothesis THyp;
+
+ const THyp* h = static_cast< ::NETGENPlugin_Hypothesis* >( myBaseImpl );
+
+ THyp::TLocalSize& lsNew = const_cast< THyp::TLocalSize& >( h->GetLocalSizesAndEntries() );
+ THyp::TLocalSize ls;
+ lsNew.swap( ls );
+
+ THyp::TLocalSize::const_iterator entry2size = ls.cbegin();
+ for ( int i = 0; entry2size != ls.cend(); ++entry2size, ++i )
+ if ( !entryArray[ i ].empty() )
+ lsNew[ entryArray[ i ]] = entry2size->second;
+
+ return true;
+}