From 63d8733b697cd2591b8ac5ac86cc1d6a1dc6301a Mon Sep 17 00:00:00 2001 From: ZXShady <153229951+ZXShady@users.noreply.github.com> Date: Fri, 14 Mar 2025 13:12:05 +0000 Subject: [PATCH] Use comparisons instead of template specilizatins --- glm/detail/qualifier.hpp | 414 +++++++++++++++++++-------------------- 1 file changed, 202 insertions(+), 212 deletions(-) diff --git a/glm/detail/qualifier.hpp b/glm/detail/qualifier.hpp index d67fd0d4..bdf65717 100644 --- a/glm/detail/qualifier.hpp +++ b/glm/detail/qualifier.hpp @@ -12,10 +12,10 @@ namespace glm packed_lowp, ///< Typed data is tightly packed in memory and operations are executed with low precision in term of ULPs to maximize performance # if GLM_CONFIG_ALIGNED_GENTYPES == GLM_ENABLE - aligned_highp, ///< Typed data is aligned in memory allowing SIMD optimizations and operations are executed with high precision in term of ULPs - aligned_mediump, ///< Typed data is aligned in memory allowing SIMD optimizations and operations are executed with high precision in term of ULPs for higher performance - aligned_lowp, // ///< Typed data is aligned in memory allowing SIMD optimizations and operations are executed with high precision in term of ULPs to maximize performance - aligned = aligned_highp, ///< By default aligned qualifier is also high precision + aligned_highp, ///< Typed data is aligned in memory allowing SIMD optimizations and operations are executed with high precision in term of ULPs + aligned_mediump, ///< Typed data is aligned in memory allowing SIMD optimizations and operations are executed with high precision in term of ULPs for higher performance + aligned_lowp, // ///< Typed data is aligned in memory allowing SIMD optimizations and operations are executed with high precision in term of ULPs to maximize performance + aligned = aligned_highp, ///< By default aligned qualifier is also high precision # endif highp = packed_highp, ///< By default highp qualifier is also packed @@ -24,9 +24,9 @@ namespace glm packed = packed_highp, ///< By default packed qualifier is also high precision # if GLM_CONFIG_ALIGNED_GENTYPES == GLM_ENABLE && defined(GLM_FORCE_DEFAULT_ALIGNED_GENTYPES) - defaultp = aligned_highp + defaultp = aligned_highp # else - defaultp = highp + defaultp = highp # endif }; @@ -37,259 +37,249 @@ namespace glm template struct qua; # if GLM_HAS_TEMPLATE_ALIASES - template using tvec1 = vec<1, T, Q>; - template using tvec2 = vec<2, T, Q>; - template using tvec3 = vec<3, T, Q>; - template using tvec4 = vec<4, T, Q>; - template using tmat2x2 = mat<2, 2, T, Q>; - template using tmat2x3 = mat<2, 3, T, Q>; - template using tmat2x4 = mat<2, 4, T, Q>; - template using tmat3x2 = mat<3, 2, T, Q>; - template using tmat3x3 = mat<3, 3, T, Q>; - template using tmat3x4 = mat<3, 4, T, Q>; - template using tmat4x2 = mat<4, 2, T, Q>; - template using tmat4x3 = mat<4, 3, T, Q>; - template using tmat4x4 = mat<4, 4, T, Q>; - template using tquat = qua; + template using tvec1 = vec<1, T, Q>; + template using tvec2 = vec<2, T, Q>; + template using tvec3 = vec<3, T, Q>; + template using tvec4 = vec<4, T, Q>; + template using tmat2x2 = mat<2, 2, T, Q>; + template using tmat2x3 = mat<2, 3, T, Q>; + template using tmat2x4 = mat<2, 4, T, Q>; + template using tmat3x2 = mat<3, 2, T, Q>; + template using tmat3x3 = mat<3, 3, T, Q>; + template using tmat3x4 = mat<3, 4, T, Q>; + template using tmat4x2 = mat<4, 2, T, Q>; + template using tmat4x3 = mat<4, 3, T, Q>; + template using tmat4x4 = mat<4, 4, T, Q>; + template using tquat = qua; # endif -namespace detail -{ - template - struct is_aligned + namespace detail { - static const bool value = false; - }; - -# if GLM_CONFIG_ALIGNED_GENTYPES == GLM_ENABLE - template<> - struct is_aligned + template + struct is_aligned { - static const bool value = true; + enum { +#if GLM_CONFIG_ALIGNED_GENTYPES == GLM_ENABLE + value = P == glm::aligned_mediump || P == glm::aligned_lowp || P == glm::aligned_highp +#else + value = false +#endif + }; }; - - template<> - struct is_aligned + template + struct storage { - static const bool value = true; + struct type { + T data[L]; + }; }; - template<> - struct is_aligned - { - static const bool value = true; - }; -# endif - - template - struct storage - { - typedef struct type { - T data[L]; - } type; - }; - # if GLM_HAS_ALIGNOF template struct storage { - typedef struct alignas(L * sizeof(T)) type { + struct alignas(L * sizeof(T)) type { T data[L]; - } type; + }; }; template struct storage<3, T, true> { - typedef struct alignas(4 * sizeof(T)) type { + struct alignas(4 * sizeof(T)) type { T data[4]; - } type; + }; }; # endif # if GLM_ARCH & GLM_ARCH_SSE2_BIT - template<> - struct storage<4, float, true> - { - typedef glm_f32vec4 type; - }; - - template<> - struct storage<4, int, true> - { - typedef glm_i32vec4 type; - }; - - template<> - struct storage<4, unsigned int, true> - { - typedef glm_u32vec4 type; - }; - - template<> - struct storage<3, float, true> - { - typedef glm_f32vec4 type; - }; - - template<> - struct storage<3, int, true> - { - typedef glm_i32vec4 type; - }; - - template<> - struct storage<3, unsigned int, true> - { - typedef glm_i32vec4 type; - }; - - template<> - struct storage<2, double, true> - { - typedef glm_f64vec2 type; - }; - - template<> - struct storage<2, detail::int64, true> - { - typedef glm_i64vec2 type; - }; - - template<> - struct storage<2, detail::uint64, true> - { - typedef glm_u64vec2 type; - }; - - - template<> - struct storage<3, detail::uint64, true> - { - typedef glm_u64vec2 type; - }; - - template<> - struct storage<4, double, true> - { -# if (GLM_ARCH & GLM_ARCH_AVX_BIT) - typedef glm_f64vec4 type; -# else - struct type + template<> + struct storage<4, float, true> { - glm_f64vec2 data[2]; - GLM_CONSTEXPR glm_f64vec2 getv(int i) const { - return data[i]; - } - GLM_CONSTEXPR void setv(int i, const glm_f64vec2& v) { - data[i] = v; - } + typedef glm_f32vec4 type; }; + + template<> + struct storage<4, int, true> + { + typedef glm_i32vec4 type; + }; + + template<> + struct storage<4, unsigned int, true> + { + typedef glm_u32vec4 type; + }; + + template<> + struct storage<3, float, true> + { + typedef glm_f32vec4 type; + }; + + template<> + struct storage<3, int, true> + { + typedef glm_i32vec4 type; + }; + + template<> + struct storage<3, unsigned int, true> + { + typedef glm_i32vec4 type; + }; + + template<> + struct storage<2, double, true> + { + typedef glm_f64vec2 type; + }; + + template<> + struct storage<2, detail::int64, true> + { + typedef glm_i64vec2 type; + }; + + template<> + struct storage<2, detail::uint64, true> + { + typedef glm_u64vec2 type; + }; + + + template<> + struct storage<3, detail::uint64, true> + { + typedef glm_u64vec2 type; + }; + + template<> + struct storage<4, double, true> + { +# if (GLM_ARCH & GLM_ARCH_AVX_BIT) + typedef glm_f64vec4 type; +# else + struct type + { + glm_f64vec2 data[2]; + GLM_CONSTEXPR glm_f64vec2 getv(int i) const { + return data[i]; + } + GLM_CONSTEXPR void setv(int i, const glm_f64vec2& v) { + data[i] = v; + } + }; # endif - }; + }; - template<> - struct storage<3, double, true> : public storage<4, double, true> - {}; - + template<> + struct storage<3, double, true> : public storage<4, double, true> + { + }; + # endif # if (GLM_ARCH & GLM_ARCH_AVX2_BIT) - template<> - struct storage<4, detail::int64, true> - { - typedef glm_i64vec4 type; - }; + template<> + struct storage<4, detail::int64, true> + { + typedef glm_i64vec4 type; + }; - template<> - struct storage<4, detail::uint64, true> - { - typedef glm_u64vec4 type; - }; + template<> + struct storage<4, detail::uint64, true> + { + typedef glm_u64vec4 type; + }; # endif # if GLM_ARCH & GLM_ARCH_NEON_BIT - template<> - struct storage<4, float, true> - { - typedef glm_f32vec4 type; - }; + template<> + struct storage<4, float, true> + { + typedef glm_f32vec4 type; + }; - template<> - struct storage<3, float, true> : public storage<4, float, true> - {}; + template<> + struct storage<3, float, true> : public storage<4, float, true> + { + }; - template<> - struct storage<4, int, true> - { - typedef glm_i32vec4 type; - }; + template<> + struct storage<4, int, true> + { + typedef glm_i32vec4 type; + }; - template<> - struct storage<3, int, true> : public storage<4, int, true> - {}; + template<> + struct storage<3, int, true> : public storage<4, int, true> + { + }; - template<> - struct storage<4, unsigned int, true> - { - typedef glm_u32vec4 type; - }; + template<> + struct storage<4, unsigned int, true> + { + typedef glm_u32vec4 type; + }; - template<> - struct storage<3, unsigned int, true> : public storage<4, unsigned int, true> - {}; + template<> + struct storage<3, unsigned int, true> : public storage<4, unsigned int, true> + { + }; # if GLM_HAS_ALIGNOF - template<> - struct storage<3, double, true> - { - typedef struct alignas(4 * sizeof(double)) type { - double data[4]; - } type; - }; + template<> + struct storage<3, double, true> + { + struct alignas(4 * sizeof(double)) type { + double data[4]; + }; + }; # endif//GLM_HAS_ALIGNOF # endif - enum genTypeEnum - { - GENTYPE_VEC, - GENTYPE_MAT, - GENTYPE_QUAT - }; - - template - struct genTypeTrait - {}; - - template - struct genTypeTrait > - { - static const genTypeEnum GENTYPE = GENTYPE_MAT; - }; - - template - struct init_gentype - { - }; - - template - struct init_gentype - { - GLM_FUNC_QUALIFIER GLM_CONSTEXPR static genType identity() + enum genTypeEnum { - return genType(1, 0, 0, 0); - } - }; + GENTYPE_VEC, + GENTYPE_MAT, + GENTYPE_QUAT + }; - template - struct init_gentype - { - GLM_FUNC_QUALIFIER GLM_CONSTEXPR static genType identity() + template + struct genTypeTrait { - return genType(1); - } - }; -}//namespace detail + }; + + template + struct genTypeTrait > + { + static const genTypeEnum GENTYPE = GENTYPE_MAT; + }; + + template + struct init_gentype + { + }; + + template + struct init_gentype + { + GLM_FUNC_QUALIFIER GLM_CONSTEXPR static genType identity() + { + return genType(1, 0, 0, 0); + } + }; + + template + struct init_gentype + { + GLM_FUNC_QUALIFIER GLM_CONSTEXPR static genType identity() + { + return genType(1); + } + }; + }//namespace detail }//namespace glm