0022458: [CEA 1039] Regressions on NETGEN_1D2D3D and "GetInPlaceByHistory"

Re-fix 22448. Remove sub-shapes inappropriate for group creation when
    it's clear that a group will be created, i.e. that nb of found sub-shapes > 1
This commit is contained in:
eap 2014-02-18 17:06:53 +04:00
parent 7d880c6a82
commit 383c7fe63a

View File

@ -3643,11 +3643,7 @@ static bool GetInPlaceOfShape (const Handle(GEOM_Function)& theWhereFunction,
{ {
if (theWhereFunction.IsNull() || theWhat.IsNull()) return false; if (theWhereFunction.IsNull() || theWhat.IsNull()) return false;
if(theWhereIndices.Contains( theWhat ) && if (theWhereIndices.Contains(theWhat)) {
(theWhat.ShapeType() == TopAbs_VERTEX || theWhat.ShapeType() == TopAbs_EDGE ||
theWhat.ShapeType() == TopAbs_FACE || theWhat.ShapeType() == TopAbs_SOLID)) {
// It is possible to add a shape only next type: vertex, edge, face or solid
// to create after a group on these elements
// entity was not changed by the operation // entity was not changed by the operation
Standard_Integer aWhatIndex = theWhereIndices.FindIndex(theWhat); Standard_Integer aWhatIndex = theWhereIndices.FindIndex(theWhat);
theModifiedList.Append(aWhatIndex); theModifiedList.Append(aWhatIndex);
@ -3702,9 +3698,6 @@ static bool GetInPlaceOfShape (const Handle(GEOM_Function)& theWhereFunction,
isGood = Standard_True; isGood = Standard_True;
Standard_Integer imod, aModifLen = anIntegerArray->Array()->Length(); Standard_Integer imod, aModifLen = anIntegerArray->Array()->Length();
for (imod = 1; imod <= aModifLen; imod++) { for (imod = 1; imod <= aModifLen; imod++) {
TopoDS_Shape curShape = theWhereIndices.FindKey(anIntegerArray->Array()->Value(imod));
if(curShape.ShapeType() == TopAbs_VERTEX || curShape.ShapeType() == TopAbs_EDGE ||
curShape.ShapeType() == TopAbs_FACE || curShape.ShapeType() == TopAbs_SOLID)
theModifiedList.Append(anIntegerArray->Array()->Value(imod)); theModifiedList.Append(anIntegerArray->Array()->Value(imod));
} }
} }
@ -4290,12 +4283,39 @@ Handle(GEOM_Object) GEOMImpl_IShapesOperations::GetInPlaceByHistory
return NULL; return NULL;
} }
Handle(TColStd_HArray1OfInteger) aModifiedArray = Standard_Integer nbFound = aModifiedList.Extent();
new TColStd_HArray1OfInteger (1, aModifiedList.Extent());
TColStd_ListIteratorOfListOfInteger anIterModif (aModifiedList); TColStd_ListIteratorOfListOfInteger anIterModif (aModifiedList);
for (Standard_Integer imod = 1; anIterModif.More(); anIterModif.Next(), imod++) { if ( nbFound > 1 )
aModifiedArray->SetValue(imod, anIterModif.Value()); {
// remove sub-shapes inappropriate for group creation
TopAbs_ShapeEnum subType = TopAbs_SHAPE;
while ( anIterModif.More() ) {
TopAbs_ShapeEnum type = aWhereIndices( anIterModif.Value() ).ShapeType();
bool okForGroup = ( type == TopAbs_VERTEX || type == TopAbs_EDGE ||
type == TopAbs_FACE || type == TopAbs_SOLID );
if ( okForGroup ) {
if ( subType == TopAbs_SHAPE )
subType = type;
else
okForGroup = ( subType == type );
} }
if ( okForGroup )
anIterModif.Next();
else
aModifiedList.Remove( anIterModif );
nbFound -= ( !okForGroup );
}
if ( nbFound == 0 ) {
SetErrorCode("Error: result found but it's type is inappropriate for group creation.");
return NULL;
}
}
Handle(TColStd_HArray1OfInteger) aModifiedArray =
new TColStd_HArray1OfInteger( 1, nbFound );
anIterModif.Initialize(aModifiedList);
for (Standard_Integer imod = 1; anIterModif.More(); anIterModif.Next(), imod++)
aModifiedArray->SetValue(imod, anIterModif.Value());
//Add a new object //Add a new object
Handle(GEOM_Object) aResult = GetEngine()->AddSubShape(theShapeWhere, aModifiedArray); Handle(GEOM_Object) aResult = GetEngine()->AddSubShape(theShapeWhere, aModifiedArray);