diff --git a/src/ShapeUpgrade/ShapeUpgrade_UnifySameDomain.cxx b/src/ShapeUpgrade/ShapeUpgrade_UnifySameDomain.cxx index 010386c99f..cf9cb3f1dd 100644 --- a/src/ShapeUpgrade/ShapeUpgrade_UnifySameDomain.cxx +++ b/src/ShapeUpgrade/ShapeUpgrade_UnifySameDomain.cxx @@ -601,7 +601,7 @@ static void TransformPCurves(const TopoDS_Face& theRefFace, const TopoDS_Face& theFace, TopTools_MapOfShape& theMapEdgesWithTemporaryPCurves) { - BRepAdaptor_Surface BAsurf(theFace, Standard_False); + BRepAdaptor_Surface BAsurf(theFace, Standard_True); //with real bounds of face Standard_Real Uperiod = 0., Vperiod = 0.; Handle(Geom_Surface) RefSurf = BRep_Tool::Surface(theRefFace); diff --git a/tests/bugs/modalg_7/bug31066 b/tests/bugs/modalg_7/bug31066 new file mode 100644 index 0000000000..8330ff1fa1 --- /dev/null +++ b/tests/bugs/modalg_7/bug31066 @@ -0,0 +1,22 @@ +puts "=======================================================" +puts "OCC31066: Infinite loop in ShapeUpgrade_UnifySameDomain" +puts "=======================================================" +puts "" + +pload MODELING DATAEXCHANGE + +stepread [locate_data_file bug31066.stp] a * + +unifysamedom result a_1 + +checkshape result + +checknbshapes result -solid 1 -shell 1 -face 140 -wire 174 -edge 352 -vertex 208 + +set tolres [checkmaxtol result] + +if { ${tolres} > 0.001} { + puts "Error: bad tolerance of result" +} + +checkprops result -v 139105