mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-28 14:30:33 +05:00
52447: Re-compute fails after hypothesis modification
This commit is contained in:
parent
05bdac9259
commit
bd39d7c3ed
@ -2299,16 +2299,31 @@ void SMESH_subMesh::setEventListener(EventListener* listener,
|
|||||||
/*!
|
/*!
|
||||||
* \brief Return an event listener data
|
* \brief Return an event listener data
|
||||||
* \param listener - the listener whose data is
|
* \param listener - the listener whose data is
|
||||||
|
* \param myOwn - if \c true, returns a listener set by this sub-mesh,
|
||||||
|
* else returns a listener listening to events of this sub-mesh
|
||||||
* \retval EventListenerData* - found data, maybe NULL
|
* \retval EventListenerData* - found data, maybe NULL
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
EventListenerData* SMESH_subMesh::GetEventListenerData(EventListener* listener) const
|
EventListenerData* SMESH_subMesh::GetEventListenerData(EventListener* listener,
|
||||||
|
const bool myOwn) const
|
||||||
|
{
|
||||||
|
if ( myOwn )
|
||||||
|
{
|
||||||
|
list< OwnListenerData >::const_iterator d;
|
||||||
|
for ( d = _ownListeners.begin(); d != _ownListeners.end(); ++d )
|
||||||
|
{
|
||||||
|
if ( d->myListener == listener && _father->MeshExists( d->myMeshID ))
|
||||||
|
return d->mySubMesh->GetEventListenerData( listener, !myOwn );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
map< EventListener*, EventListenerData* >::const_iterator l_d =
|
map< EventListener*, EventListenerData* >::const_iterator l_d =
|
||||||
_eventListeners.find( listener );
|
_eventListeners.find( listener );
|
||||||
if ( l_d != _eventListeners.end() )
|
if ( l_d != _eventListeners.end() )
|
||||||
return l_d->second;
|
return l_d->second;
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2316,16 +2331,31 @@ EventListenerData* SMESH_subMesh::GetEventListenerData(EventListener* listener)
|
|||||||
/*!
|
/*!
|
||||||
* \brief Return an event listener data
|
* \brief Return an event listener data
|
||||||
* \param listenerName - the listener name
|
* \param listenerName - the listener name
|
||||||
|
* \param myOwn - if \c true, returns a listener set by this sub-mesh,
|
||||||
|
* else returns a listener listening to events of this sub-mesh
|
||||||
* \retval EventListenerData* - found data, maybe NULL
|
* \retval EventListenerData* - found data, maybe NULL
|
||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
EventListenerData* SMESH_subMesh::GetEventListenerData(const string& listenerName) const
|
EventListenerData* SMESH_subMesh::GetEventListenerData(const string& listenerName,
|
||||||
|
const bool myOwn) const
|
||||||
|
{
|
||||||
|
if ( myOwn )
|
||||||
|
{
|
||||||
|
list< OwnListenerData >::const_iterator d;
|
||||||
|
for ( d = _ownListeners.begin(); d != _ownListeners.end(); ++d )
|
||||||
|
{
|
||||||
|
if ( _father->MeshExists( d->myMeshID ) && listenerName == d->myListener->GetName())
|
||||||
|
return d->mySubMesh->GetEventListenerData( listenerName, !myOwn );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
map< EventListener*, EventListenerData* >::const_iterator l_d = _eventListeners.begin();
|
map< EventListener*, EventListenerData* >::const_iterator l_d = _eventListeners.begin();
|
||||||
for ( ; l_d != _eventListeners.end(); ++l_d )
|
for ( ; l_d != _eventListeners.end(); ++l_d )
|
||||||
if ( listenerName == l_d->first->GetName() )
|
if ( listenerName == l_d->first->GetName() )
|
||||||
return l_d->second;
|
return l_d->second;
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -139,16 +139,22 @@ class SMESH_EXPORT SMESH_subMesh
|
|||||||
/*!
|
/*!
|
||||||
* \brief Return an event listener data
|
* \brief Return an event listener data
|
||||||
* \param listener - the listener whose data is
|
* \param listener - the listener whose data is
|
||||||
|
* \param myOwn - if \c true, returns a listener set by this sub-mesh,
|
||||||
|
* else returns a listener listening to events of this sub-mesh
|
||||||
* \retval EventListenerData* - found data, maybe NULL
|
* \retval EventListenerData* - found data, maybe NULL
|
||||||
*/
|
*/
|
||||||
EventListenerData* GetEventListenerData(EventListener* listener) const;
|
EventListenerData* GetEventListenerData(EventListener* listener,
|
||||||
|
const bool myOwn=false) const;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Return an event listener data
|
* \brief Return an event listener data
|
||||||
* \param listenerName - the listener name
|
* \param listenerName - the listener name
|
||||||
|
* \param myOwn - if \c true, returns a listener set by this sub-mesh,
|
||||||
|
* else returns a listener listening to events of this sub-mesh
|
||||||
* \retval EventListenerData* - found data, maybe NULL
|
* \retval EventListenerData* - found data, maybe NULL
|
||||||
*/
|
*/
|
||||||
EventListenerData* GetEventListenerData(const std::string& listenerName) const;
|
EventListenerData* GetEventListenerData(const std::string& listenerName,
|
||||||
|
const bool myOwn=false) const;
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief Unregister the listener and delete it and it's data
|
* \brief Unregister the listener and delete it and it's data
|
||||||
|
@ -2382,6 +2382,17 @@ void StdMeshers_ProjectionUtils::SetEventListener(SMESH_subMesh* subMesh,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if ( SMESH_subMeshEventListenerData* data =
|
||||||
|
srcShapeSM->GetEventListenerData( getSrcSubMeshListener() ))
|
||||||
|
{
|
||||||
|
bool alreadyIn =
|
||||||
|
(std::find( data->mySubMeshes.begin(),
|
||||||
|
data->mySubMeshes.end(), subMesh ) != data->mySubMeshes.end() );
|
||||||
|
if ( !alreadyIn )
|
||||||
|
data->mySubMeshes.push_back( subMesh );
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
subMesh->SetEventListener( getSrcSubMeshListener(),
|
subMesh->SetEventListener( getSrcSubMeshListener(),
|
||||||
SMESH_subMeshEventListenerData::MakeData( subMesh ),
|
SMESH_subMeshEventListenerData::MakeData( subMesh ),
|
||||||
@ -2390,3 +2401,4 @@ void StdMeshers_ProjectionUtils::SetEventListener(SMESH_subMesh* subMesh,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user