From 9dad7df5ee6e520b2b2f63bc5b9373b27003ff6e Mon Sep 17 00:00:00 2001 From: sharkautarch <128002472+sharkautarch@users.noreply.github.com> Date: Sun, 15 Sep 2024 12:21:13 -0400 Subject: [PATCH] constexpr simd vec: mixed element type constructor: fix nullptr being passed to memcpy --- glm/detail/simd_constexpr/vec.hpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/glm/detail/simd_constexpr/vec.hpp b/glm/detail/simd_constexpr/vec.hpp index 5532b2e81..ebb964440 100644 --- a/glm/detail/simd_constexpr/vec.hpp +++ b/glm/detail/simd_constexpr/vec.hpp @@ -295,7 +295,7 @@ namespace glm return 1; } } - static inline auto ctor_mixed_constexpr_single = [](auto vs0) -> auto + static inline decltype(auto) ctor_mixed_constexpr_single = [](auto vs0) -> auto { using VTX = decltype(vs0); if constexpr ( std::is_integral_v || std::is_floating_point_v ) { @@ -353,16 +353,19 @@ namespace glm const auto params = std::tuple{vecOrScalar...}; const auto arr = ctor_mixed_constexpr_single(std::get<0>(params)); - std::memcpy(aa.a.p.begin()+i, arr, sizeof(T)*lengths[0]); + if (arr) + std::memcpy(aa.a.p.begin()+i, arr, sizeof(T)*lengths[0]); constexpr auto i2 = i + lengths[0]; if constexpr (sizeof...(VecOrScalar) > 1) { const auto arr2 = ctor_mixed_constexpr_single(std::get<1>(params)); - std::memcpy(aa.a.p.begin()+i2, arr2, sizeof(T)*lengths[1]); + if (arr2) + std::memcpy(aa.a.p.begin()+i2, arr2, sizeof(T)*lengths[1]); constexpr auto i3 = i2 + lengths[1]; if constexpr (sizeof...(VecOrScalar) > 2) { const auto arr3 = ctor_mixed_constexpr_single(std::get<2>(params)); - std::memcpy(aa.a.p.begin()+i3, arr3, sizeof(T)*lengths[2]); + if (arr3) + std::memcpy(aa.a.p.begin()+i3, arr3, sizeof(T)*lengths[2]); } }