PAL16202,16203 (Propagation 1D on edges group)

remove useless includes and fix SetEventListener()
This commit is contained in:
eap 2007-11-07 09:43:35 +00:00
parent 90bfa44674
commit 9ebce0b2a6

View File

@ -44,14 +44,13 @@
#include <BRep_Builder.hxx> #include <BRep_Builder.hxx>
#include <BRep_Tool.hxx> #include <BRep_Tool.hxx>
#include <TopExp.hxx> #include <TopExp.hxx>
#include <TopTools_IndexedDataMapOfShapeListOfShape.hxx>
#include <TopTools_IndexedMapOfShape.hxx> #include <TopTools_IndexedMapOfShape.hxx>
#include <TopTools_ListIteratorOfListOfShape.hxx> #include <TopTools_ListIteratorOfListOfShape.hxx>
#include <TopTools_ListOfShape.hxx>
#include <TopTools_MapOfShape.hxx>
#include <TopoDS.hxx> #include <TopoDS.hxx>
#include <TopoDS_Compound.hxx> #include <TopoDS_Compound.hxx>
#include <gp_Pnt.hxx> #include <gp_Pnt.hxx>
#include <TopExp_Explorer.hxx>
#include <TopoDS_Iterator.hxx>
#include <Standard_OutOfMemory.hxx> #include <Standard_OutOfMemory.hxx>
#include <Standard_ErrorHandler.hxx> #include <Standard_ErrorHandler.hxx>
@ -1926,8 +1925,9 @@ void SMESH_subMesh::SetEventListener(EventListener* listener, EventListenerData*
map< EventListener*, EventListenerData* >::iterator l_d = map< EventListener*, EventListenerData* >::iterator l_d =
myEventListeners.find( listener ); myEventListeners.find( listener );
if ( l_d != myEventListeners.end() ) { if ( l_d != myEventListeners.end() ) {
if ( l_d->second && l_d->second->IsDeletable() ) EventListenerData* curData = l_d->second;
delete l_d->second; if ( curData && curData != data && curData->IsDeletable() )
delete curData;
l_d->second = data; l_d->second = data;
} }
else else
@ -2028,13 +2028,17 @@ void SMESH_subMeshEventListener::ProcessEvent(const int event,
eventType == SMESH_subMesh::COMPUTE_EVENT) eventType == SMESH_subMesh::COMPUTE_EVENT)
{ {
ASSERT( data->mySubMeshes.front() != subMesh ); ASSERT( data->mySubMeshes.front() != subMesh );
list<SMESH_subMesh*>::iterator smIt = data->mySubMeshes.begin();
list<SMESH_subMesh*>::iterator smEnd = data->mySubMeshes.end();
switch ( event ) { switch ( event ) {
case SMESH_subMesh::CLEAN: case SMESH_subMesh::CLEAN:
data->mySubMeshes.front()->ComputeStateEngine( event ); for ( ; smIt != smEnd; ++ smIt)
(*smIt)->ComputeStateEngine( event );
break; break;
case SMESH_subMesh::COMPUTE: case SMESH_subMesh::COMPUTE:
if ( subMesh->GetComputeState() == SMESH_subMesh::COMPUTE_OK ) if ( subMesh->GetComputeState() == SMESH_subMesh::COMPUTE_OK )
data->mySubMeshes.front()->ComputeStateEngine( SMESH_subMesh::SUBMESH_COMPUTED ); for ( ; smIt != smEnd; ++ smIt)
(*smIt)->ComputeStateEngine( SMESH_subMesh::SUBMESH_COMPUTED );
break; break;
default:; default:;
} }