- Handle(SALOME_TypeFilter) GeomFilter = new SALOME_TypeFilter( "GEOM" );
- if ( !GeomFilter->IsOk(anObj) )
- return false;
-
- Handle(GEOM_ShapeTypeFilter) GeomShapeTypeFilter = new GEOM_ShapeTypeFilter( TopAbs_EDGE, myComponentGeom );
- if ( !GeomShapeTypeFilter->IsOk(anObj) )
- return false;
-
- if ( anObj->hasEntry() ) {
- QAD_Study* ActiveStudy = QAD_Application::getDesktop()->getActiveStudy();
- SALOMEDS::Study_var aStudy = ActiveStudy->getStudyDocument();
- SALOMEDS::SObject_var obj = aStudy->FindObjectID( anObj->getEntry() );
- SALOMEDS::GenericAttribute_var anAttr;
- SALOMEDS::AttributeIOR_var anIOR;
- if ( !obj->_is_nil() ) {
- if (obj->FindAttribute(anAttr, "AttributeIOR")) {
- anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr);
- GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( anIOR->Value() );
- if ( aShape->_is_nil() )
- return false;
-
- TopoDS_Shape Shape = ShapeReader.GetShape( myComponentGeom, aShape );
- if ( Shape.IsNull() )
- return false;
-
- switch (myKind) {
- case StdSelect_AnyEdge:
- return Standard_True;
- case StdSelect_Line:
- {
- BRepAdaptor_Curve curv(TopoDS::Edge(Shape));
- return (curv.GetType() == GeomAbs_Line);
- }
- break;
- case StdSelect_Circle:
- BRepAdaptor_Curve curv(TopoDS::Edge(Shape));
- return (curv.GetType() == GeomAbs_Circle);
- }
- }
- }
- }
-
- if ( anObj->IsInstance(STANDARD_TYPE(GEOM_InteractiveObject)) ) {
- Handle(GEOM_InteractiveObject) GObject =
- Handle(GEOM_InteractiveObject)::DownCast(anObj);
-
- GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( GObject->getIOR() );
- if ( aShape->_is_nil() )
- return false;
-
- TopoDS_Shape Shape = ShapeReader.GetShape( myComponentGeom, aShape );
- if ( Shape.IsNull() )
- return false;
-
- switch (myKind) {
- case StdSelect_AnyEdge:
- return Standard_True;
- case StdSelect_Line:
- {
- BRepAdaptor_Curve curv(TopoDS::Edge(Shape));
- return (curv.GetType() == GeomAbs_Line);
- }
- break;
- case StdSelect_Circle:
- BRepAdaptor_Curve curv(TopoDS::Edge(Shape));
- return (curv.GetType() == GeomAbs_Circle);
+ if ( !theShape.IsNull() && theShape.ShapeType() == TopAbs_EDGE )
+ {
+ BRepAdaptor_Curve aCurve( TopoDS::Edge( theShape ) );
+ GeomAbs_CurveType aType = aCurve.GetType();
+
+ switch ( myKind )
+ {
+ case StdSelect_AnyEdge: return Standard_True;
+ case StdSelect_Line: return ( aType == GeomAbs_Line );
+ case StdSelect_Circle: return ( aType == GeomAbs_Circle );