X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FNETGENPlugin%2FNETGENPlugin_Hypothesis_i.cxx;h=6344bb5cea8048d9a54dd0838c5b6083d6c5315e;hb=ab749f8f58fd82c99134f77f8f7e9a9a3f895fd1;hp=0deff9aeddd62387f32d39db2ac03b1c4f2407a1;hpb=005805f161667ed0cfd6f90060b262c9869dc215;p=plugins%2Fnetgenplugin.git diff --git a/src/NETGENPlugin/NETGENPlugin_Hypothesis_i.cxx b/src/NETGENPlugin/NETGENPlugin_Hypothesis_i.cxx index 0deff9a..6344bb5 100644 --- a/src/NETGENPlugin/NETGENPlugin_Hypothesis_i.cxx +++ b/src/NETGENPlugin/NETGENPlugin_Hypothesis_i.cxx @@ -1,4 +1,4 @@ -// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE +// Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE // // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS @@ -6,7 +6,7 @@ // 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. +// 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 @@ -59,15 +59,12 @@ bool NETGENPlugin_Hypothesis_i::isToSetParameter(double curValue, //============================================================================= 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); } @@ -80,7 +77,6 @@ NETGENPlugin_Hypothesis_i (PortableServer::POA_ptr thePOA, //============================================================================= NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i() { - MESSAGE( "NETGENPlugin_Hypothesis_i::~NETGENPlugin_Hypothesis_i" ); } //============================================================================= @@ -309,11 +305,44 @@ CORBA::Double NETGENPlugin_Hypothesis_i::GetNbSegPerRadius() //============================================================================= +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) { string entry; entry = GeomObj->GetStudyEntry(); + if ( entry.empty() ) + THROW_SALOME_CORBA_EXCEPTION( "SetLocalSizeOnShape(), shape is not published in study!", + SALOME::BAD_PARAM ); SetLocalSizeOnEntry(entry.c_str(), localSize); } @@ -344,7 +373,7 @@ NETGENPlugin::string_array* NETGENPlugin_Hypothesis_i::GetLocalSizeEntries() 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++) { @@ -359,7 +388,25 @@ NETGENPlugin::string_array* NETGENPlugin_Hypothesis_i::GetLocalSizeEntries() 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() ); } //============================================================================= @@ -382,6 +429,239 @@ CORBA::Boolean NETGENPlugin_Hypothesis_i::GetQuadAllowed() return this->GetImpl()->GetQuadAllowed(); } +//============================================================================= + +void NETGENPlugin_Hypothesis_i::SetUseSurfaceCurvature (CORBA::Boolean theValue) +{ + if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetUseSurfaceCurvature(), + theValue, + METH_SetSurfaceCurvature )) + { + this->GetImpl()->SetSurfaceCurvature(theValue); + SMESH::TPythonDump() << _this() << ".SetUseSurfaceCurvature( " << theValue << " )"; + } +} + +//============================================================================= + +CORBA::Boolean NETGENPlugin_Hypothesis_i::GetUseSurfaceCurvature() +{ + return this->GetImpl()->GetSurfaceCurvature(); +} + +//============================================================================= + +void NETGENPlugin_Hypothesis_i::SetFuseEdges (CORBA::Boolean theValue) +{ + if ( NETGENPlugin_Hypothesis_i::isToSetParameter( GetFuseEdges(), + theValue, + METH_SetFuseEdges )) + { + this->GetImpl()->SetFuseEdges(theValue); + SMESH::TPythonDump() << _this() << ".SetFuseEdges( " << theValue << " )"; + } +} + +//============================================================================= + +CORBA::Boolean NETGENPlugin_Hypothesis_i::GetFuseEdges() +{ + 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 @@ -396,13 +676,13 @@ CORBA::Boolean NETGENPlugin_Hypothesis_i::GetQuadAllowed() //================================================================================ /*! - * \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; @@ -446,3 +726,51 @@ std::string NETGENPlugin_Hypothesis_i::getMethodOfParameter(const int paramIndex } 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; +}