From dff941292ac5915524b812b9b555acad26dad17f Mon Sep 17 00:00:00 2001 From: jfa Date: Fri, 14 Jun 2024 13:32:10 +0100 Subject: [PATCH] [bos #42181] Fatal error in Fuse selection NCollection_DataMap::Find --- src/AIS/AIS_Selection.cxx | 10 ++++------ 1 file changed, 4 insertions(+), 6 deletions(-) diff --git a/src/AIS/AIS_Selection.cxx b/src/AIS/AIS_Selection.cxx index 874ba363bb..039f3004ca 100644 --- a/src/AIS/AIS_Selection.cxx +++ b/src/AIS/AIS_Selection.cxx @@ -65,8 +65,11 @@ AIS_SelectStatus AIS_Selection::Select(const Handle(SelectMgr_EntityOwner)& theO const Standard_Boolean wasSelected = theOwner->IsSelected(); const Standard_Boolean toSelect = theOwner->Select(theSelScheme, isDetected); - if (toSelect && !wasSelected) + if (!wasSelected || !myResultMap.IsBound(theOwner)) { + if (!toSelect) + return AIS_SS_NotDone; + AIS_NListOfEntityOwner::Iterator aListIter; myresult.Append(theOwner, aListIter); myResultMap.Bind(theOwner, aListIter); @@ -74,11 +77,6 @@ AIS_SelectStatus AIS_Selection::Select(const Handle(SelectMgr_EntityOwner)& theO return AIS_SS_Added; } - if (!toSelect && !wasSelected) - { - return AIS_SS_NotDone; - } - AIS_NListOfEntityOwner::Iterator aListIter = myResultMap.Find(theOwner); if (myIterator == aListIter) {