From 679942033e633f163e37405642b9906ee4026642 Mon Sep 17 00:00:00 2001 From: "mhochsteger@cerbsim.com" Date: Mon, 7 Mar 2022 20:59:00 +0100 Subject: [PATCH] thread safe ExtrusionFace :: CalcProj --- libsrc/csg/extrusion.cpp | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/libsrc/csg/extrusion.cpp b/libsrc/csg/extrusion.cpp index 8584597a..1d3cdafb 100644 --- a/libsrc/csg/extrusion.cpp +++ b/libsrc/csg/extrusion.cpp @@ -141,16 +141,21 @@ namespace netgen void ExtrusionFace :: CalcProj(const Point<3> & point3d, Point<2> & point2d, int & seg, double & t) const { - if (Dist2 (point3d, latest_point3d) < - 1e-25 * Dist2(path->GetSpline(0).StartPI(), path->GetSpline(0).EndPI())) + static mutex set_latest_point; + + auto eps = 1e-25 * Dist2(path->GetSpline(0).StartPI(), path->GetSpline(0).EndPI()); + if (Dist2 (point3d, latest_point3d) < eps) { - point2d = latest_point2d; - seg = latest_seg; - t = latest_t; - return; + std::lock_guard guard(set_latest_point); + if (Dist2 (point3d, latest_point3d) < eps) + { + point2d = latest_point2d; + seg = latest_seg; + t = latest_t; + return; + } } - latest_point3d = point3d; double cutdist = -1; @@ -214,11 +219,13 @@ namespace netgen point2d = testpoint2d; t = thist; seg = i; - latest_seg = i; - latest_t = t; - latest_point2d = point2d; } } + std::lock_guard guard(set_latest_point); + latest_seg = seg; + latest_t = t; + latest_point2d = point2d; + latest_point3d = point3d; } double ExtrusionFace :: CalcProj(const Point<3> & point3d, Point<2> & point2d,