From 89682777f7aaf6ec0b3cccf21320ccd4576dcfc7 Mon Sep 17 00:00:00 2001 From: eap Date: Mon, 29 Apr 2013 14:18:32 +0000 Subject: [PATCH] 0022202: EDF SMESH: Regression in a script meshing prisms and hexaedrons Fix notifyListenersOnEvent() for the case of removing an EventListener (attempt No.2) --- src/SMESH/SMESH_subMesh.cxx | 31 ++++++++++++------------------- 1 file changed, 12 insertions(+), 19 deletions(-) diff --git a/src/SMESH/SMESH_subMesh.cxx b/src/SMESH/SMESH_subMesh.cxx index ba6118097..19df51879 100644 --- a/src/SMESH/SMESH_subMesh.cxx +++ b/src/SMESH/SMESH_subMesh.cxx @@ -2258,29 +2258,22 @@ void SMESH_subMesh::notifyListenersOnEvent( const int event, const event_type eventType, SMESH_Hypothesis* hyp) { - set< EventListener* > notified; - const size_t nbListeners = _eventListeners.size(); - while ( notified.size() != nbListeners ) + list< pair< EventListener*, EventListenerData* > > eventListeners( _eventListeners.begin(), + _eventListeners.end()); + list< pair< EventListener*, EventListenerData* > >::iterator l_d = eventListeners.begin(); + for ( ; l_d != eventListeners.end(); ++l_d ) { - map< EventListener*, EventListenerData* >::iterator l_d = _eventListeners.begin(); - for ( ; l_d != _eventListeners.end(); ++l_d ) + std::pair< EventListener*, EventListenerData* > li_da = *l_d; + if ( !_eventListeners.count( li_da.first )) continue; + + if ( li_da.first->myBusySM.insert( this ).second ) { - std::pair< EventListener*, EventListenerData* > li_da = *l_d; + const bool isDeletable = li_da.first->IsDeletable(); - if ( notified.insert( li_da.first ).second && - li_da.first->myBusySM.insert( this ).second ) - { - const bool isDeletable = li_da.first->IsDeletable(); + li_da.first->ProcessEvent( event, eventType, this, li_da.second, hyp ); - li_da.first->ProcessEvent( event, eventType, this, li_da.second, hyp ); - - const bool isRemoved = !_eventListeners.count( li_da.first ); - if ( !isDeletable || !isRemoved ) - li_da.first->myBusySM.erase( this ); // a listener is hopefully not dead - - if ( isRemoved ) - break; // restart looping on _eventListeners - } + if ( !isDeletable || !_eventListeners.count( li_da.first )) + li_da.first->myBusySM.erase( this ); // a listener is hopefully not dead } } }