diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2025-04-24 01:31:27 +0100 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2025-04-24 01:31:27 +0100 |
commit | 84358a17c18aa8e23f9508f4fa3a864e27d51697 (patch) | |
tree | 3ccf5d616a629056a1b007fc718e26940f019800 /lib | |
parent | Fix all warnings game/network/* (diff) | |
download | ilt-84358a17c18aa8e23f9508f4fa3a864e27d51697.tar.bz2 ilt-84358a17c18aa8e23f9508f4fa3a864e27d51697.tar.xz ilt-84358a17c18aa8e23f9508f4fa3a864e27d51697.zip |
Avoid out parameters with Ray::intersectTriangle
Diffstat (limited to 'lib')
-rw-r--r-- | lib/ray.h | 22 |
1 files changed, 17 insertions, 5 deletions
@@ -53,17 +53,29 @@ public: } } - bool - intersectTriangle(const PositionType t0, const PositionType t1, const PositionType t2, BaryPosition & bary, - RelativeDistance & distance) const + struct IntersectTriangleResult { + BaryPosition bary; + RelativeDistance distance; + }; + + std::optional<IntersectTriangleResult> + intersectTriangle(const PositionType t0, const PositionType t1, const PositionType t2) const { + IntersectTriangleResult out; if constexpr (std::is_floating_point_v<typename PositionType::value_type>) { - return glm::intersectRayTriangle(start, direction, t0, t1, t2, bary, distance) && distance >= 0.F; + if (glm::intersectRayTriangle(start, direction, t0, t1, t2, out.bary, out.distance) + && out.distance >= 0.F) { + return out; + } } else { const RelativePosition3D t0r = t0 - start, t1r = t1 - start, t2r = t2 - start; - return glm::intersectRayTriangle({}, direction, t0r, t1r, t2r, bary, distance) && distance >= 0.F; + if (glm::intersectRayTriangle({}, direction, t0r, t1r, t2r, out.bary, out.distance) + && out.distance >= 0.F) { + return out; + } } + return std::nullopt; } bool |