From 588493c920516300c8b8ca08c47d02ec0673b6e4 Mon Sep 17 00:00:00 2001 From: eap Date: Tue, 24 Mar 2015 14:35:25 +0300 Subject: [PATCH] 23028: EDF 10508 SMESH: GroupOnFilter returns an empty group when the geometry is not published --- src/SMESH_I/SMESH_Filter_i.cxx | 76 ++++++++++++++++++++++------------ 1 file changed, 49 insertions(+), 27 deletions(-) diff --git a/src/SMESH_I/SMESH_Filter_i.cxx b/src/SMESH_I/SMESH_Filter_i.cxx index fa32444eb..1165cc93f 100644 --- a/src/SMESH_I/SMESH_Filter_i.cxx +++ b/src/SMESH_I/SMESH_Filter_i.cxx @@ -756,7 +756,8 @@ void BelongToGeom_i::SetGeom( const TopoDS_Shape& theShape ) myBelongToGeomPtr->SetGeom( theShape ); } -void BelongToGeom_i::SetElementType(ElementType theType){ +void BelongToGeom_i::SetElementType(ElementType theType) +{ myBelongToGeomPtr->SetType(SMDSAbs_ElementType(theType)); TPythonDump()<SetGeom( getShapeByID(myShapeID) ); + TopoDS_Shape S; + if ( hasName && hasID ) + { + S = getShapeByID( myShapeID ); + if ( S.IsNull() ) + S = getShapeByName( myShapeName ); + } else - myBelongToGeomPtr->SetGeom( getShapeByName( myShapeName ) ); + { + S = hasID ? getShapeByID( myShapeID ) : getShapeByName( myShapeName ); + } + myBelongToGeomPtr->SetGeom( S ); } char* BelongToGeom_i::GetShapeName() @@ -862,17 +870,24 @@ void BelongToSurface_i::SetShapeName( const char* theName, ElementType theType ) void BelongToSurface_i::SetShape( const char* theID, const char* theName, ElementType theType ) { delete myShapeName; - myShapeName = strdup( theName ); delete myShapeID; - if ( theID ) - myShapeID = strdup( theID ); - else - myShapeID = 0; - - if ( myShapeID && myShapeName == getShapeNameByID(myShapeID)) - myElementsOnSurfacePtr->SetSurface( getShapeByID(myShapeID), (SMDSAbs_ElementType)theType ); + myShapeName = strdup( theName ); + myShapeID = strdup( theID ); + bool hasName = ( theName && theName[0] ); + bool hasID = ( theID && theID[0] ); + + TopoDS_Shape S; + if ( hasName && hasID ) + { + S = getShapeByID( myShapeID ); + if ( S.IsNull() ) + S = getShapeByName( myShapeName ); + } else - myElementsOnSurfacePtr->SetSurface( getShapeByName( myShapeName ), (SMDSAbs_ElementType)theType ); + { + S = hasID ? getShapeByID( myShapeID ) : getShapeByName( myShapeName ); + } + myElementsOnSurfacePtr->SetSurface( S, (SMDSAbs_ElementType)theType ); } char* BelongToSurface_i::GetShapeName() @@ -1032,17 +1047,24 @@ void LyingOnGeom_i::SetShapeName( const char* theName ) void LyingOnGeom_i::SetShape( const char* theID, const char* theName ) { delete myShapeName; - myShapeName = strdup( theName ); delete myShapeID; - if ( theID ) - myShapeID = strdup( theID ); - else - myShapeID = 0; - - if ( myShapeID && myShapeName == getShapeNameByID(myShapeID)) - myLyingOnGeomPtr->SetGeom( getShapeByID(myShapeID) ); + myShapeName = strdup( theName ); + myShapeID = strdup( theID ); + bool hasName = ( theName && theName[0] ); + bool hasID = ( theID && theID[0] ); + + TopoDS_Shape S; + if ( hasName && hasID ) + { + S = getShapeByID( myShapeID ); + if ( S.IsNull() ) + S = getShapeByName( myShapeName ); + } else - myLyingOnGeomPtr->SetGeom( getShapeByName( myShapeName ) ); + { + S = hasID ? getShapeByID( myShapeID ) : getShapeByName( myShapeName ); + } + myLyingOnGeomPtr->SetGeom( S ); } char* LyingOnGeom_i::GetShapeName() -- 2.39.2