From df6f165a2b572d53142a776cde62682676ab1179 Mon Sep 17 00:00:00 2001 From: ika Date: Wed, 11 Jul 2018 17:29:34 +0300 Subject: [PATCH] 0029945: Export body of revolution to STEP breaks the shape Now vertex loops on surfaces of revolution are imported from STEP format in the same way as on spheres and b-spline surfaces: in case of a single vertex loop neutral bounds will be used. --- src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx | 4 +++- tests/bugs/step/bug29945 | 11 +++++++++++ 2 files changed, 14 insertions(+), 1 deletion(-) create mode 100644 tests/bugs/step/bug29945 diff --git a/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx b/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx index 6de7d28d34..7b99345644 100644 --- a/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx +++ b/src/StepToTopoDS/StepToTopoDS_TranslateFace.cxx @@ -37,6 +37,7 @@ #include #include #include +#include #include #include #include @@ -246,7 +247,8 @@ void StepToTopoDS_TranslateFace::Init // abv 10.07.00 pr1sy.stp: vertex_loop can be wrong; so just make natural bounds if (GeomSurf->IsKind (STANDARD_TYPE(Geom_SphericalSurface)) || - GeomSurf->IsKind (STANDARD_TYPE(Geom_BSplineSurface)) ) + GeomSurf->IsKind (STANDARD_TYPE(Geom_BSplineSurface)) || + GeomSurf->IsKind (STANDARD_TYPE(Geom_SurfaceOfRevolution))) { if (NbBnd ==1 || FaceBound->IsKind(STANDARD_TYPE(StepShape_FaceOuterBound))) { BRepBuilderAPI_MakeFace mf (GeomSurf, Precision()); diff --git a/tests/bugs/step/bug29945 b/tests/bugs/step/bug29945 new file mode 100644 index 0000000000..dd344748df --- /dev/null +++ b/tests/bugs/step/bug29945 @@ -0,0 +1,11 @@ +puts "==========" +puts "OCC29945" +puts "==========" +puts "" +######################################################### +# Export body of revolution to STEP breaks the shape +######################################################### + +testreadstep [locate_data_file bug29945.stp] res + +checkshape res