From 78443328165be1420e625963423ec9afa26f1527 Mon Sep 17 00:00:00 2001 From: Christophe Riccio Date: Sat, 14 Feb 2015 13:56:48 +0100 Subject: [PATCH] Fixed memory corruption (undefined behaviour) #303 --- glm/detail/type_mat2x2.hpp | 3 ++ glm/detail/type_mat2x2.inl | 15 ++++++ glm/detail/type_mat2x3.hpp | 72 +++++++++----------------- glm/detail/type_mat2x3.inl | 15 ++++++ glm/detail/type_mat2x4.hpp | 74 +++++++++----------------- glm/detail/type_mat2x4.inl | 15 ++++++ glm/detail/type_mat3x2.hpp | 72 +++++++++----------------- glm/detail/type_mat3x2.inl | 17 ++++++ glm/detail/type_mat3x3.hpp | 100 ++++++++++++------------------------ glm/detail/type_mat3x3.inl | 17 ++++++ glm/detail/type_mat3x4.hpp | 3 ++ glm/detail/type_mat3x4.inl | 17 ++++++ glm/detail/type_mat4x2.hpp | 17 +++--- glm/detail/type_mat4x2.inl | 19 +++++++ glm/detail/type_mat4x3.hpp | 3 ++ glm/detail/type_mat4x3.inl | 19 +++++++ glm/detail/type_mat4x4.hpp | 3 ++ glm/detail/type_mat4x4.inl | 21 ++++++++ glm/detail/type_vec2.hpp | 52 +++++++++---------- glm/detail/type_vec4.hpp | 4 +- glm/detail/type_vec4.inl | 15 ++++++ glm/gtc/quaternion.hpp | 18 +++++-- glm/gtc/quaternion.inl | 69 ++++++++++++++++++------- glm/gtx/dual_quaternion.hpp | 11 +++- glm/gtx/dual_quaternion.inl | 37 ++++++++++--- 25 files changed, 430 insertions(+), 278 deletions(-) diff --git a/glm/detail/type_mat2x2.hpp b/glm/detail/type_mat2x2.hpp index eac1034a0..046ceac3c 100644 --- a/glm/detail/type_mat2x2.hpp +++ b/glm/detail/type_mat2x2.hpp @@ -63,6 +63,7 @@ namespace glm ////////////////////////////////////// // Constructors GLM_FUNC_DECL tmat2x2(); + GLM_FUNC_DECL tmat2x2(tmat2x2 const & m); template GLM_FUNC_DECL tmat2x2(tmat2x2 const & m); @@ -127,6 +128,8 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat2x2 & operator=(tmat2x2 const & v); + template GLM_FUNC_DECL tmat2x2 & operator=(tmat2x2 const & m); template diff --git a/glm/detail/type_mat2x2.inl b/glm/detail/type_mat2x2.inl index cac40352d..779cc091a 100644 --- a/glm/detail/type_mat2x2.inl +++ b/glm/detail/type_mat2x2.inl @@ -62,6 +62,13 @@ namespace detail # endif } + template + GLM_FUNC_QUALIFIER tmat2x2::tmat2x2(tmat2x2 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + } + template template GLM_FUNC_QUALIFIER tmat2x2::tmat2x2(tmat2x2 const & m) @@ -236,6 +243,14 @@ namespace detail ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat2x2& tmat2x2::operator=(tmat2x2 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat2x2& tmat2x2::operator=(tmat2x2 const & m) diff --git a/glm/detail/type_mat2x3.hpp b/glm/detail/type_mat2x3.hpp index f6a6caecc..9986e881b 100644 --- a/glm/detail/type_mat2x3.hpp +++ b/glm/detail/type_mat2x3.hpp @@ -58,6 +58,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat2x3(); + GLM_FUNC_DECL tmat2x3(tmat2x3 const & m); template GLM_FUNC_DECL tmat2x3(tmat2x3 const & m); @@ -123,20 +124,22 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat2x3 & operator=(tmat2x3 const & m); + template - GLM_FUNC_DECL tmat2x3 & operator= (tmat2x3 const & m); + GLM_FUNC_DECL tmat2x3 & operator=(tmat2x3 const & m); template - GLM_FUNC_DECL tmat2x3 & operator+= (U s); + GLM_FUNC_DECL tmat2x3 & operator+=(U s); template - GLM_FUNC_DECL tmat2x3 & operator+= (tmat2x3 const & m); + GLM_FUNC_DECL tmat2x3 & operator+=(tmat2x3 const & m); template - GLM_FUNC_DECL tmat2x3 & operator-= (U s); + GLM_FUNC_DECL tmat2x3 & operator-=(U s); template - GLM_FUNC_DECL tmat2x3 & operator-= (tmat2x3 const & m); + GLM_FUNC_DECL tmat2x3 & operator-=(tmat2x3 const & m); template - GLM_FUNC_DECL tmat2x3 & operator*= (U s); + GLM_FUNC_DECL tmat2x3 & operator*=(U s); template - GLM_FUNC_DECL tmat2x3 & operator/= (U s); + GLM_FUNC_DECL tmat2x3 & operator/=(U s); ////////////////////////////////////// // Increment and decrement operators @@ -150,74 +153,47 @@ namespace glm // Binary operators template - GLM_FUNC_DECL tmat2x3 operator+ ( - tmat2x3 const & m, - T const & s); + GLM_FUNC_DECL tmat2x3 operator+(tmat2x3 const & m, T const & s); template - GLM_FUNC_DECL tmat2x3 operator+ ( - tmat2x3 const & m1, - tmat2x3 const & m2); + GLM_FUNC_DECL tmat2x3 operator+(tmat2x3 const & m1, tmat2x3 const & m2); template - GLM_FUNC_DECL tmat2x3 operator- ( - tmat2x3 const & m, - T const & s); + GLM_FUNC_DECL tmat2x3 operator-(tmat2x3 const & m, T const & s); template - GLM_FUNC_DECL tmat2x3 operator- ( - tmat2x3 const & m1, - tmat2x3 const & m2); + GLM_FUNC_DECL tmat2x3 operator-(tmat2x3 const & m1, tmat2x3 const & m2); template - GLM_FUNC_DECL tmat2x3 operator* ( - tmat2x3 const & m, - T const & s); + GLM_FUNC_DECL tmat2x3 operator*(tmat2x3 const & m, T const & s); template - GLM_FUNC_DECL tmat2x3 operator* ( - T const & s, - tmat2x3 const & m); + GLM_FUNC_DECL tmat2x3 operator*(T const & s, tmat2x3 const & m); template - GLM_FUNC_DECL typename tmat2x3::col_type operator* ( - tmat2x3 const & m, - typename tmat2x3::row_type const & v); + GLM_FUNC_DECL typename tmat2x3::col_type operator*(tmat2x3 const & m, typename tmat2x3::row_type const & v); template - GLM_FUNC_DECL typename tmat2x3::row_type operator* ( - typename tmat2x3::col_type const & v, - tmat2x3 const & m); + GLM_FUNC_DECL typename tmat2x3::row_type operator*(typename tmat2x3::col_type const & v, tmat2x3 const & m); template - GLM_FUNC_DECL tmat2x3 operator* ( - tmat2x3 const & m1, - tmat2x2 const & m2); + GLM_FUNC_DECL tmat2x3 operator*(tmat2x3 const & m1, tmat2x2 const & m2); template - GLM_FUNC_DECL tmat3x3 operator* ( - tmat2x3 const & m1, - tmat3x2 const & m2); + GLM_FUNC_DECL tmat3x3 operator*(tmat2x3 const & m1, tmat3x2 const & m2); template - GLM_FUNC_DECL tmat4x3 operator* ( - tmat2x3 const & m1, - tmat4x2 const & m2); + GLM_FUNC_DECL tmat4x3 operator*(tmat2x3 const & m1, tmat4x2 const & m2); template - GLM_FUNC_DECL tmat2x3 operator/ ( - tmat2x3 const & m, - T const & s); + GLM_FUNC_DECL tmat2x3 operator/(tmat2x3 const & m, T const & s); template - GLM_FUNC_DECL tmat2x3 operator/ ( - T const & s, - tmat2x3 const & m); + GLM_FUNC_DECL tmat2x3 operator/(T const & s, tmat2x3 const & m); // Unary constant operators template - GLM_FUNC_DECL tmat2x3 const operator- ( - tmat2x3 const & m); + GLM_FUNC_DECL tmat2x3 const operator-(tmat2x3 const & m); }//namespace glm #ifndef GLM_EXTERNAL_TEMPLATE diff --git a/glm/detail/type_mat2x3.inl b/glm/detail/type_mat2x3.inl index 126f58585..32c30fdd9 100644 --- a/glm/detail/type_mat2x3.inl +++ b/glm/detail/type_mat2x3.inl @@ -44,6 +44,13 @@ namespace glm # endif } + template + GLM_FUNC_QUALIFIER tmat2x3::tmat2x3(tmat2x3 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + } + template template GLM_FUNC_QUALIFIER tmat2x3::tmat2x3(tmat2x3 const & m) @@ -220,6 +227,14 @@ namespace glm ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat2x3& tmat2x3::operator=(tmat2x3 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat2x3& tmat2x3::operator=(tmat2x3 const & m) diff --git a/glm/detail/type_mat2x4.hpp b/glm/detail/type_mat2x4.hpp index 7087e06ce..9239e9c9b 100644 --- a/glm/detail/type_mat2x4.hpp +++ b/glm/detail/type_mat2x4.hpp @@ -58,6 +58,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat2x4(); + GLM_FUNC_DECL tmat2x4(tmat2x4 const & m); template GLM_FUNC_DECL tmat2x4(tmat2x4 const & m); @@ -124,20 +125,22 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat2x4 & operator=(tmat2x4 const & m); + template - GLM_FUNC_DECL tmat2x4& operator= (tmat2x4 const & m); + GLM_FUNC_DECL tmat2x4 & operator=(tmat2x4 const & m); template - GLM_FUNC_DECL tmat2x4& operator+= (U s); + GLM_FUNC_DECL tmat2x4 & operator+=(U s); template - GLM_FUNC_DECL tmat2x4& operator+= (tmat2x4 const & m); + GLM_FUNC_DECL tmat2x4 & operator+=(tmat2x4 const & m); template - GLM_FUNC_DECL tmat2x4& operator-= (U s); + GLM_FUNC_DECL tmat2x4 & operator-=(U s); template - GLM_FUNC_DECL tmat2x4& operator-= (tmat2x4 const & m); + GLM_FUNC_DECL tmat2x4 & operator-=(tmat2x4 const & m); template - GLM_FUNC_DECL tmat2x4& operator*= (U s); + GLM_FUNC_DECL tmat2x4 & operator*=(U s); template - GLM_FUNC_DECL tmat2x4& operator/= (U s); + GLM_FUNC_DECL tmat2x4 & operator/=(U s); ////////////////////////////////////// // Increment and decrement operators @@ -151,74 +154,47 @@ namespace glm // Binary operators template - GLM_FUNC_DECL tmat2x4 operator+ ( - tmat2x4 const & m, - T const & s); + GLM_FUNC_DECL tmat2x4 operator+(tmat2x4 const & m, T const & s); template - GLM_FUNC_DECL tmat2x4 operator+ ( - tmat2x4 const & m1, - tmat2x4 const & m2); + GLM_FUNC_DECL tmat2x4 operator+(tmat2x4 const & m1, tmat2x4 const & m2); template - GLM_FUNC_DECL tmat2x4 operator- ( - tmat2x4 const & m, - T const & s); + GLM_FUNC_DECL tmat2x4 operator-(tmat2x4 const & m, T const & s); template - GLM_FUNC_DECL tmat2x4 operator- ( - tmat2x4 const & m1, - tmat2x4 const & m2); + GLM_FUNC_DECL tmat2x4 operator-(tmat2x4 const & m1, tmat2x4 const & m2); template - GLM_FUNC_DECL tmat2x4 operator* ( - tmat2x4 const & m, - T const & s); + GLM_FUNC_DECL tmat2x4 operator*(tmat2x4 const & m, T const & s); template - GLM_FUNC_DECL tmat2x4 operator* ( - T const & s, - tmat2x4 const & m); + GLM_FUNC_DECL tmat2x4 operator*(T const & s, tmat2x4 const & m); template - GLM_FUNC_DECL typename tmat2x4::col_type operator* ( - tmat2x4 const & m, - typename tmat2x4::row_type const & v); + GLM_FUNC_DECL typename tmat2x4::col_type operator*(tmat2x4 const & m, typename tmat2x4::row_type const & v); template - GLM_FUNC_DECL typename tmat2x4::row_type operator* ( - typename tmat2x4::col_type const & v, - tmat2x4 const & m); + GLM_FUNC_DECL typename tmat2x4::row_type operator*(typename tmat2x4::col_type const & v, tmat2x4 const & m); template - GLM_FUNC_DECL tmat4x4 operator* ( - tmat2x4 const & m1, - tmat4x2 const & m2); + GLM_FUNC_DECL tmat4x4 operator*(tmat2x4 const & m1, tmat4x2 const & m2); template - GLM_FUNC_DECL tmat2x4 operator* ( - tmat2x4 const & m1, - tmat2x2 const & m2); - + GLM_FUNC_DECL tmat2x4 operator*(tmat2x4 const & m1, tmat2x2 const & m2); + template - GLM_FUNC_DECL tmat3x4 operator* ( - tmat2x4 const & m1, - tmat3x2 const & m2); + GLM_FUNC_DECL tmat3x4 operator*(tmat2x4 const & m1, tmat3x2 const & m2); template - GLM_FUNC_DECL tmat2x4 operator/ ( - tmat2x4 const & m, - T s); + GLM_FUNC_DECL tmat2x4 operator/(tmat2x4 const & m, T s); template - GLM_FUNC_DECL tmat2x4 operator/ ( - T s, - tmat2x4 const & m); + GLM_FUNC_DECL tmat2x4 operator/(T s, tmat2x4 const & m); // Unary constant operators template - GLM_FUNC_DECL tmat2x4 const operator- ( - tmat2x4 const & m); + GLM_FUNC_DECL tmat2x4 const operator-(tmat2x4 const & m); }//namespace glm #ifndef GLM_EXTERNAL_TEMPLATE diff --git a/glm/detail/type_mat2x4.inl b/glm/detail/type_mat2x4.inl index a7b89643d..fcf5d315a 100644 --- a/glm/detail/type_mat2x4.inl +++ b/glm/detail/type_mat2x4.inl @@ -44,6 +44,13 @@ namespace glm # endif } + template + GLM_FUNC_QUALIFIER tmat2x4::tmat2x4(tmat2x4 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + } + template template GLM_FUNC_QUALIFIER tmat2x4::tmat2x4(tmat2x4 const & m) @@ -221,6 +228,14 @@ namespace glm ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat2x4& tmat2x4::operator=(tmat2x4 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat2x4& tmat2x4::operator=(tmat2x4 const & m) diff --git a/glm/detail/type_mat3x2.hpp b/glm/detail/type_mat3x2.hpp index 0ba7cfebb..9fd573f21 100644 --- a/glm/detail/type_mat3x2.hpp +++ b/glm/detail/type_mat3x2.hpp @@ -58,6 +58,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat3x2(); + GLM_FUNC_DECL tmat3x2(tmat3x2 const & m); template GLM_FUNC_DECL tmat3x2(tmat3x2 const & m); @@ -130,20 +131,22 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat3x2 & operator=(tmat3x2 const & m); + template - GLM_FUNC_DECL tmat3x2 & operator= (tmat3x2 const & m); + GLM_FUNC_DECL tmat3x2 & operator=(tmat3x2 const & m); template - GLM_FUNC_DECL tmat3x2 & operator+= (U s); + GLM_FUNC_DECL tmat3x2 & operator+=(U s); template - GLM_FUNC_DECL tmat3x2 & operator+= (tmat3x2 const & m); + GLM_FUNC_DECL tmat3x2 & operator+=(tmat3x2 const & m); template - GLM_FUNC_DECL tmat3x2 & operator-= (U s); + GLM_FUNC_DECL tmat3x2 & operator-=(U s); template - GLM_FUNC_DECL tmat3x2 & operator-= (tmat3x2 const & m); + GLM_FUNC_DECL tmat3x2 & operator-=(tmat3x2 const & m); template - GLM_FUNC_DECL tmat3x2 & operator*= (U s); + GLM_FUNC_DECL tmat3x2 & operator*=(U s); template - GLM_FUNC_DECL tmat3x2 & operator/= (U s); + GLM_FUNC_DECL tmat3x2 & operator/=(U s); ////////////////////////////////////// // Increment and decrement operators @@ -156,74 +159,47 @@ namespace glm // Binary operators template - GLM_FUNC_DECL tmat3x2 operator+ ( - tmat3x2 const & m, - T const & s); + GLM_FUNC_DECL tmat3x2 operator+(tmat3x2 const & m, T const & s); template - GLM_FUNC_DECL tmat3x2 operator+ ( - tmat3x2 const & m1, - tmat3x2 const & m2); + GLM_FUNC_DECL tmat3x2 operator+(tmat3x2 const & m1, tmat3x2 const & m2); template - GLM_FUNC_DECL tmat3x2 operator- ( - tmat3x2 const & m, - T const & s); + GLM_FUNC_DECL tmat3x2 operator-(tmat3x2 const & m, T const & s); template - GLM_FUNC_DECL tmat3x2 operator- ( - tmat3x2 const & m1, - tmat3x2 const & m2); + GLM_FUNC_DECL tmat3x2 operator-(tmat3x2 const & m1, tmat3x2 const & m2); template - GLM_FUNC_DECL tmat3x2 operator* ( - tmat3x2 const & m, - T const & s); + GLM_FUNC_DECL tmat3x2 operator*(tmat3x2 const & m, T const & s); template - GLM_FUNC_DECL tmat3x2 operator* ( - T const & s, - tmat3x2 const & m); + GLM_FUNC_DECL tmat3x2 operator*(T const & s, tmat3x2 const & m); template - GLM_FUNC_DECL typename tmat3x2::col_type operator* ( - tmat3x2 const & m, - typename tmat3x2::row_type const & v); + GLM_FUNC_DECL typename tmat3x2::col_type operator*(tmat3x2 const & m, typename tmat3x2::row_type const & v); template - GLM_FUNC_DECL typename tmat3x2::row_type operator* ( - typename tmat3x2::col_type const & v, - tmat3x2 const & m); + GLM_FUNC_DECL typename tmat3x2::row_type operator*(typename tmat3x2::col_type const & v, tmat3x2 const & m); template - GLM_FUNC_DECL tmat2x2 operator* ( - tmat3x2 const & m1, - tmat2x3 const & m2); + GLM_FUNC_DECL tmat2x2 operator*(tmat3x2 const & m1, tmat2x3 const & m2); template - GLM_FUNC_DECL tmat3x2 operator* ( - tmat3x2 const & m1, - tmat3x3 const & m2); + GLM_FUNC_DECL tmat3x2 operator*(tmat3x2 const & m1, tmat3x3 const & m2); template - GLM_FUNC_DECL tmat4x2 operator* ( - tmat3x2 const & m1, - tmat4x3 const & m2); + GLM_FUNC_DECL tmat4x2 operator*(tmat3x2 const & m1, tmat4x3 const & m2); template - GLM_FUNC_DECL tmat3x2 operator/ ( - tmat3x2 const & m, - T const & s); + GLM_FUNC_DECL tmat3x2 operator/(tmat3x2 const & m, T const & s); template - GLM_FUNC_DECL tmat3x2 operator/ ( - T const & s, - tmat3x2 const & m); + GLM_FUNC_DECL tmat3x2 operator/(T const & s, tmat3x2 const & m); // Unary constant operators template - GLM_FUNC_DECL tmat3x2 const operator-( - tmat3x2 const & m); + GLM_FUNC_DECL tmat3x2 const operator-(tmat3x2 const & m); }//namespace glm #ifndef GLM_EXTERNAL_TEMPLATE diff --git a/glm/detail/type_mat3x2.inl b/glm/detail/type_mat3x2.inl index e4f4d42d2..d42a9aec5 100644 --- a/glm/detail/type_mat3x2.inl +++ b/glm/detail/type_mat3x2.inl @@ -45,6 +45,14 @@ namespace glm # endif } + template + GLM_FUNC_QUALIFIER tmat3x2::tmat3x2(tmat3x2 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + this->value[2] = m.value[2]; + } + template template GLM_FUNC_QUALIFIER tmat3x2::tmat3x2(tmat3x2 const & m) @@ -249,6 +257,15 @@ namespace glm ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat3x2& tmat3x2::operator=(tmat3x2 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat3x2& tmat3x2::operator=(tmat3x2 const & m) diff --git a/glm/detail/type_mat3x3.hpp b/glm/detail/type_mat3x3.hpp index 9064cee94..dddfc535d 100644 --- a/glm/detail/type_mat3x3.hpp +++ b/glm/detail/type_mat3x3.hpp @@ -62,6 +62,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat3x3(); + GLM_FUNC_DECL tmat3x3(tmat3x3 const & m); template GLM_FUNC_DECL tmat3x3(tmat3x3 const & m); @@ -134,129 +135,94 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat3x3 & operator=(tmat3x3 const & m); + template - GLM_FUNC_DECL tmat3x3& operator= (tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 & operator=(tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3& operator+= (U s); + GLM_FUNC_DECL tmat3x3 & operator+=(U s); template - GLM_FUNC_DECL tmat3x3& operator+= (tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 & operator+=(tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3& operator-= (U s); + GLM_FUNC_DECL tmat3x3 & operator-=(U s); template - GLM_FUNC_DECL tmat3x3& operator-= (tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 & operator-=(tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3& operator*= (U s); + GLM_FUNC_DECL tmat3x3 & operator*=(U s); template - GLM_FUNC_DECL tmat3x3& operator*= (tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 & operator*=(tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3& operator/= (U s); + GLM_FUNC_DECL tmat3x3 & operator/=(U s); template - GLM_FUNC_DECL tmat3x3& operator/= (tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 & operator/=(tmat3x3 const & m); ////////////////////////////////////// // Increment and decrement operators - GLM_FUNC_DECL tmat3x3 & operator++ (); - GLM_FUNC_DECL tmat3x3 & operator-- (); + GLM_FUNC_DECL tmat3x3 & operator++(); + GLM_FUNC_DECL tmat3x3 & operator--(); GLM_FUNC_DECL tmat3x3 operator++(int); GLM_FUNC_DECL tmat3x3 operator--(int); }; // Binary operators template - GLM_FUNC_DECL tmat3x3 operator+ ( - tmat3x3 const & m, - T const & s); + GLM_FUNC_DECL tmat3x3 operator+(tmat3x3 const & m, T const & s); template - GLM_FUNC_DECL tmat3x3 operator+ ( - T const & s, - tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 operator+(T const & s, tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3 operator+ ( - tmat3x3 const & m1, - tmat3x3 const & m2); + GLM_FUNC_DECL tmat3x3 operator+(tmat3x3 const & m1, tmat3x3 const & m2); template - GLM_FUNC_DECL tmat3x3 operator- ( - tmat3x3 const & m, - T const & s); + GLM_FUNC_DECL tmat3x3 operator-(tmat3x3 const & m, T const & s); template - GLM_FUNC_DECL tmat3x3 operator- ( - T const & s, - tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 operator-(T const & s, tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3 operator- ( - tmat3x3 const & m1, - tmat3x3 const & m2); + GLM_FUNC_DECL tmat3x3 operator-(tmat3x3 const & m1, tmat3x3 const & m2); template - GLM_FUNC_DECL tmat3x3 operator* ( - tmat3x3 const & m, - T const & s); + GLM_FUNC_DECL tmat3x3 operator*(tmat3x3 const & m, T const & s); template - GLM_FUNC_DECL tmat3x3 operator* ( - T const & s, - tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 operator*(T const & s, tmat3x3 const & m); template - GLM_FUNC_DECL typename tmat3x3::col_type operator* ( - tmat3x3 const & m, - typename tmat3x3::row_type const & v); + GLM_FUNC_DECL typename tmat3x3::col_type operator*(tmat3x3 const & m, typename tmat3x3::row_type const & v); template - GLM_FUNC_DECL typename tmat3x3::row_type operator* ( - typename tmat3x3::col_type const & v, - tmat3x3 const & m); + GLM_FUNC_DECL typename tmat3x3::row_type operator*(typename tmat3x3::col_type const & v, tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3 operator* ( - tmat3x3 const & m1, - tmat3x3 const & m2); + GLM_FUNC_DECL tmat3x3 operator*(tmat3x3 const & m1, tmat3x3 const & m2); template - GLM_FUNC_DECL tmat2x3 operator* ( - tmat3x3 const & m1, - tmat2x3 const & m2); + GLM_FUNC_DECL tmat2x3 operator*(tmat3x3 const & m1, tmat2x3 const & m2); template - GLM_FUNC_DECL tmat4x3 operator* ( - tmat3x3 const & m1, - tmat4x3 const & m2); + GLM_FUNC_DECL tmat4x3 operator*(tmat3x3 const & m1, tmat4x3 const & m2); template - GLM_FUNC_DECL tmat3x3 operator/ ( - tmat3x3 const & m, - T const & s); + GLM_FUNC_DECL tmat3x3 operator/(tmat3x3 const & m, T const & s); template - GLM_FUNC_DECL tmat3x3 operator/ ( - T const & s, - tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 operator/(T const & s, tmat3x3 const & m); template - GLM_FUNC_DECL typename tmat3x3::col_type operator/ ( - tmat3x3 const & m, - typename tmat3x3::row_type const & v); + GLM_FUNC_DECL typename tmat3x3::col_type operator/(tmat3x3 const & m, typename tmat3x3::row_type const & v); template - GLM_FUNC_DECL typename tmat3x3::row_type operator/ ( - typename tmat3x3::col_type const & v, - tmat3x3 const & m); + GLM_FUNC_DECL typename tmat3x3::row_type operator/(typename tmat3x3::col_type const & v, tmat3x3 const & m); template - GLM_FUNC_DECL tmat3x3 operator/ ( - tmat3x3 const & m1, - tmat3x3 const & m2); + GLM_FUNC_DECL tmat3x3 operator/(tmat3x3 const & m1, tmat3x3 const & m2); // Unary constant operators template - GLM_FUNC_DECL tmat3x3 const operator-( - tmat3x3 const & m); + GLM_FUNC_DECL tmat3x3 const operator-(tmat3x3 const & m); }//namespace glm #ifndef GLM_EXTERNAL_TEMPLATE diff --git a/glm/detail/type_mat3x3.inl b/glm/detail/type_mat3x3.inl index de7c24ee5..ad933d36d 100644 --- a/glm/detail/type_mat3x3.inl +++ b/glm/detail/type_mat3x3.inl @@ -73,6 +73,14 @@ namespace detail GLM_FUNC_QUALIFIER tmat3x3::tmat3x3(ctor) {} + template + GLM_FUNC_QUALIFIER tmat3x3::tmat3x3(tmat3x3 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + this->value[2] = m.value[2]; + } + template template GLM_FUNC_QUALIFIER tmat3x3::tmat3x3(tmat3x3 const & m) @@ -273,6 +281,15 @@ namespace detail ////////////////////////////////////////////////////////////// // Operators + template + GLM_FUNC_QUALIFIER tmat3x3 & tmat3x3::operator=(tmat3x3 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat3x3 & tmat3x3::operator=(tmat3x3 const & m) diff --git a/glm/detail/type_mat3x4.hpp b/glm/detail/type_mat3x4.hpp index 8222ea45d..7814e3fdb 100644 --- a/glm/detail/type_mat3x4.hpp +++ b/glm/detail/type_mat3x4.hpp @@ -58,6 +58,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat3x4(); + GLM_FUNC_DECL tmat3x4(tmat3x4 const & m); template GLM_FUNC_DECL tmat3x4(tmat3x4 const & m); @@ -129,6 +130,8 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat3x4 & operator=(tmat3x4 const & m); + template GLM_FUNC_DECL tmat3x4 & operator=(tmat3x4 const & m); template diff --git a/glm/detail/type_mat3x4.inl b/glm/detail/type_mat3x4.inl index cf474c1aa..03e0c2cf8 100644 --- a/glm/detail/type_mat3x4.inl +++ b/glm/detail/type_mat3x4.inl @@ -45,6 +45,14 @@ namespace glm # endif } + template + GLM_FUNC_QUALIFIER tmat3x4::tmat3x4(tmat3x4 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + this->value[2] = m.value[2]; + } + template template GLM_FUNC_QUALIFIER tmat3x4::tmat3x4(tmat3x4 const & m) @@ -248,6 +256,15 @@ namespace glm ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat3x4& tmat3x4::operator=(tmat3x4 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat3x4& tmat3x4::operator=(tmat3x4 const & m) diff --git a/glm/detail/type_mat4x2.hpp b/glm/detail/type_mat4x2.hpp index 2ad1affc2..d529ecbdb 100644 --- a/glm/detail/type_mat4x2.hpp +++ b/glm/detail/type_mat4x2.hpp @@ -58,6 +58,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat4x2(); + GLM_FUNC_DECL tmat4x2(tmat4x2 const & m); template GLM_FUNC_DECL tmat4x2(tmat4x2 const & m); @@ -135,20 +136,22 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat4x2 & operator=(tmat4x2 const & m); + template - GLM_FUNC_DECL tmat4x2& operator=(tmat4x2 const & m); + GLM_FUNC_DECL tmat4x2 & operator=(tmat4x2 const & m); template - GLM_FUNC_DECL tmat4x2& operator+=(U s); + GLM_FUNC_DECL tmat4x2 & operator+=(U s); template - GLM_FUNC_DECL tmat4x2& operator+=(tmat4x2 const & m); + GLM_FUNC_DECL tmat4x2 & operator+=(tmat4x2 const & m); template - GLM_FUNC_DECL tmat4x2& operator-=(U s); + GLM_FUNC_DECL tmat4x2 & operator-=(U s); template - GLM_FUNC_DECL tmat4x2& operator-=(tmat4x2 const & m); + GLM_FUNC_DECL tmat4x2 & operator-=(tmat4x2 const & m); template - GLM_FUNC_DECL tmat4x2& operator*=(U s); + GLM_FUNC_DECL tmat4x2 & operator*=(U s); template - GLM_FUNC_DECL tmat4x2& operator/=(U s); + GLM_FUNC_DECL tmat4x2 & operator/=(U s); ////////////////////////////////////// // Increment and decrement operators diff --git a/glm/detail/type_mat4x2.inl b/glm/detail/type_mat4x2.inl index 977a9f51f..dac9ff066 100644 --- a/glm/detail/type_mat4x2.inl +++ b/glm/detail/type_mat4x2.inl @@ -46,6 +46,15 @@ namespace glm # endif } + template + GLM_FUNC_QUALIFIER tmat4x2::tmat4x2(tmat4x2 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + this->value[2] = m.value[2]; + this->value[3] = m.value[3]; + } + template template GLM_FUNC_QUALIFIER tmat4x2::tmat4x2(tmat4x2 const & m) @@ -271,6 +280,16 @@ namespace glm ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat4x2& tmat4x2::operator=(tmat4x2 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + this->value[3] = m[3]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat4x2& tmat4x2::operator=(tmat4x2 const & m) diff --git a/glm/detail/type_mat4x3.hpp b/glm/detail/type_mat4x3.hpp index 54c8ee7f8..8bde1ac0a 100644 --- a/glm/detail/type_mat4x3.hpp +++ b/glm/detail/type_mat4x3.hpp @@ -57,6 +57,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat4x3(); + GLM_FUNC_DECL tmat4x3(tmat4x3 const & m); template GLM_FUNC_DECL tmat4x3(tmat4x3 const & m); @@ -134,6 +135,8 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat4x3 & operator=(tmat4x3 const & m); + template GLM_FUNC_DECL tmat4x3 & operator=(tmat4x3 const & m); template diff --git a/glm/detail/type_mat4x3.inl b/glm/detail/type_mat4x3.inl index b38682e7e..d5c62c8ac 100644 --- a/glm/detail/type_mat4x3.inl +++ b/glm/detail/type_mat4x3.inl @@ -46,6 +46,15 @@ namespace glm # endif } + template + GLM_FUNC_QUALIFIER tmat4x3::tmat4x3(tmat4x3 const & m) + { + this->value[0] = m.value[0]; + this->value[1] = m.value[1]; + this->value[2] = m.value[2]; + this->value[3] = m.value[3]; + } + template template GLM_FUNC_QUALIFIER tmat4x3::tmat4x3(tmat4x3 const & m) @@ -271,6 +280,16 @@ namespace glm ////////////////////////////////////////////////////////////// // Unary updatable operators + template + GLM_FUNC_QUALIFIER tmat4x3& tmat4x3::operator=(tmat4x3 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + this->value[3] = m[3]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat4x3& tmat4x3::operator=(tmat4x3 const & m) diff --git a/glm/detail/type_mat4x4.hpp b/glm/detail/type_mat4x4.hpp index 61519090a..dcb7269b9 100644 --- a/glm/detail/type_mat4x4.hpp +++ b/glm/detail/type_mat4x4.hpp @@ -62,6 +62,7 @@ namespace glm public: // Constructors GLM_FUNC_DECL tmat4x4(); + GLM_FUNC_DECL tmat4x4(tmat4x4 const & m); template GLM_FUNC_DECL tmat4x4(tmat4x4 const & m); @@ -139,6 +140,8 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + GLM_FUNC_DECL tmat4x4 & operator=(tmat4x4 const & m); + template GLM_FUNC_DECL tmat4x4 & operator=(tmat4x4 const & m); template diff --git a/glm/detail/type_mat4x4.inl b/glm/detail/type_mat4x4.inl index 534706b9a..103be5b65 100644 --- a/glm/detail/type_mat4x4.inl +++ b/glm/detail/type_mat4x4.inl @@ -106,6 +106,15 @@ namespace detail # endif } + template + GLM_FUNC_QUALIFIER tmat4x4::tmat4x4(tmat4x4 const & m) + { + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + this->value[3] = m[3]; + } + template template GLM_FUNC_QUALIFIER tmat4x4::tmat4x4(tmat4x4 const & m) @@ -357,6 +366,18 @@ namespace detail ////////////////////////////////////////////////////////////// // Operators + template + GLM_FUNC_QUALIFIER tmat4x4& tmat4x4::operator=(tmat4x4 const & m) + { + //memcpy could be faster + //memcpy(&this->value, &m.value, 16 * sizeof(valType)); + this->value[0] = m[0]; + this->value[1] = m[1]; + this->value[2] = m[2]; + this->value[3] = m[3]; + return *this; + } + template template GLM_FUNC_QUALIFIER tmat4x4& tmat4x4::operator=(tmat4x4 const & m) diff --git a/glm/detail/type_vec2.hpp b/glm/detail/type_vec2.hpp index 15fe74e01..29cfa0924 100644 --- a/glm/detail/type_vec2.hpp +++ b/glm/detail/type_vec2.hpp @@ -163,34 +163,34 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators - GLM_FUNC_DECL tvec2 & operator=(tvec2 const & v); + GLM_FUNC_DECL tvec2& operator=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator=(tvec2 const & v); + GLM_FUNC_DECL tvec2& operator=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator+=(U s); + GLM_FUNC_DECL tvec2& operator+=(U s); template - GLM_FUNC_DECL tvec2 & operator+=(tvec1 const & v); + GLM_FUNC_DECL tvec2& operator+=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator+=(tvec2 const & v); + GLM_FUNC_DECL tvec2& operator+=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator-=(U s); + GLM_FUNC_DECL tvec2& operator-=(U s); template - GLM_FUNC_DECL tvec2 & operator-=(tvec1 const & v); + GLM_FUNC_DECL tvec2& operator-=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator-=(tvec2 const & v); + GLM_FUNC_DECL tvec2& operator-=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator*=(U s); + GLM_FUNC_DECL tvec2& operator*=(U s); template - GLM_FUNC_DECL tvec2 & operator*=(tvec1 const & v); + GLM_FUNC_DECL tvec2& operator*=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator*=(tvec2 const & v); + GLM_FUNC_DECL tvec2& operator*=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator/=(U s); + GLM_FUNC_DECL tvec2& operator/=(U s); template - GLM_FUNC_DECL tvec2 & operator/=(tvec1 const & v); + GLM_FUNC_DECL tvec2& operator/=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator/=(tvec2 const & v); + GLM_FUNC_DECL tvec2& operator/=(tvec2 const & v); ////////////////////////////////////// // Increment and decrement operators @@ -204,29 +204,29 @@ namespace glm // Unary bit operators template - GLM_FUNC_DECL tvec2 & operator%= (U s); + GLM_FUNC_DECL tvec2 & operator%=(U s); template - GLM_FUNC_DECL tvec2 & operator%= (tvec1 const & v); + GLM_FUNC_DECL tvec2 & operator%=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator%= (tvec2 const & v); + GLM_FUNC_DECL tvec2 & operator%=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator&= (U s); + GLM_FUNC_DECL tvec2 & operator&=(U s); template - GLM_FUNC_DECL tvec2 & operator&= (tvec1 const & v); + GLM_FUNC_DECL tvec2 & operator&=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator&= (tvec2 const & v); + GLM_FUNC_DECL tvec2 & operator&=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator|= (U s); + GLM_FUNC_DECL tvec2 & operator|=(U s); template - GLM_FUNC_DECL tvec2 & operator|= (tvec1 const & v); + GLM_FUNC_DECL tvec2 & operator|=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator|= (tvec2 const & v); + GLM_FUNC_DECL tvec2 & operator|=(tvec2 const & v); template - GLM_FUNC_DECL tvec2 & operator^= (U s); + GLM_FUNC_DECL tvec2 & operator^=(U s); template - GLM_FUNC_DECL tvec2 & operator^= (tvec1 const & v); + GLM_FUNC_DECL tvec2 & operator^=(tvec1 const & v); template - GLM_FUNC_DECL tvec2 & operator^= (tvec2 const & v); + GLM_FUNC_DECL tvec2 & operator^=(tvec2 const & v); template GLM_FUNC_DECL tvec2 & operator<<=(U s); template diff --git a/glm/detail/type_vec4.hpp b/glm/detail/type_vec4.hpp index 408d2de44..8189d6f08 100644 --- a/glm/detail/type_vec4.hpp +++ b/glm/detail/type_vec4.hpp @@ -167,7 +167,7 @@ namespace detail // Implicit basic constructors GLM_FUNC_DECL tvec4(); - //GLM_FUNC_DECL tvec4(tvec4 const & v); + GLM_FUNC_DECL tvec4(tvec4 const & v); template GLM_FUNC_DECL tvec4(tvec4 const & v); @@ -285,7 +285,7 @@ namespace detail ////////////////////////////////////// // Unary arithmetic operators - //GLM_FUNC_DECL tvec4 & operator=(tvec4 const & v); + GLM_FUNC_DECL tvec4 & operator=(tvec4 const & v); template GLM_FUNC_DECL tvec4 & operator=(tvec4 const & v); diff --git a/glm/detail/type_vec4.inl b/glm/detail/type_vec4.inl index e1db10af8..fbdf51fc5 100644 --- a/glm/detail/type_vec4.inl +++ b/glm/detail/type_vec4.inl @@ -42,6 +42,11 @@ namespace glm # endif {} + template + GLM_FUNC_QUALIFIER tvec4::tvec4(tvec4 const & v) + : x(v.x), y(v.y), z(v.z), w(v.w) + {} + template template GLM_FUNC_QUALIFIER tvec4::tvec4(tvec4 const & v) @@ -245,6 +250,16 @@ namespace glm ////////////////////////////////////// // Unary arithmetic operators + template + GLM_FUNC_QUALIFIER tvec4 & tvec4::operator=(tvec4 const & v) + { + this->x = v.x; + this->y = v.y; + this->z = v.z; + this->w = v.w; + return *this; + } + template template GLM_FUNC_QUALIFIER tvec4 & tvec4::operator=(tvec4 const & v) diff --git a/glm/gtc/quaternion.hpp b/glm/gtc/quaternion.hpp index f98e705f1..0735abf83 100644 --- a/glm/gtc/quaternion.hpp +++ b/glm/gtc/quaternion.hpp @@ -91,6 +91,7 @@ namespace glm // Implicit basic constructors GLM_FUNC_DECL tquat(); + GLM_FUNC_DECL tquat(tquat const & q); template GLM_FUNC_DECL tquat(tquat const & q); @@ -133,10 +134,19 @@ namespace glm ////////////////////////////////////// // Operators - GLM_FUNC_DECL tquat & operator+=(tquat const & q); - GLM_FUNC_DECL tquat & operator*=(tquat const & q); - GLM_FUNC_DECL tquat & operator*=(T const & s); - GLM_FUNC_DECL tquat & operator/=(T const & s); + + GLM_FUNC_DECL tquat & operator=(tquat const & m); + + template + GLM_FUNC_DECL tquat & operator=(tquat const & m); + template + GLM_FUNC_DECL tquat & operator+=(tquat const & q); + template + GLM_FUNC_DECL tquat & operator*=(tquat const & q); + template + GLM_FUNC_DECL tquat & operator*=(U s); + template + GLM_FUNC_DECL tquat & operator/=(U s); }; template diff --git a/glm/gtc/quaternion.inl b/glm/gtc/quaternion.inl index 46c032960..33ca82cc0 100644 --- a/glm/gtc/quaternion.inl +++ b/glm/gtc/quaternion.inl @@ -104,6 +104,11 @@ namespace detail # endif {} + template + GLM_FUNC_QUALIFIER tquat::tquat(tquat const & q) + : x(q.x), y(q.y), z(q.z), w(q.w) + {} + template template GLM_FUNC_QUALIFIER tquat::tquat(tquat const & q) @@ -176,7 +181,7 @@ namespace detail this->w = c.x * c.y * c.z + s.x * s.y * s.z; this->x = s.x * c.y * c.z - c.x * s.y * s.z; this->y = c.x * s.y * c.z + s.x * c.y * s.z; - this->z = c.x * c.y * s.z - s.x * s.y * c.z; + this->z = c.x * c.y * s.z - s.x * s.y * c.z; } template @@ -221,19 +226,43 @@ namespace detail // tquat operators template - GLM_FUNC_QUALIFIER tquat & tquat::operator+=(tquat const & q) + GLM_FUNC_QUALIFIER tquat & tquat::operator=(tquat const & q) + { + this->w = q.w; + this->x = q.x; + this->y = q.y; + this->z = q.z; + return *this; + } + + template + template + GLM_FUNC_QUALIFIER tquat & tquat::operator=(tquat const & q) + { + this->w = static_cast(q.w); + this->x = static_cast(q.x); + this->y = static_cast(q.y); + this->z = static_cast(q.z); + return *this; + } + + template + template + GLM_FUNC_QUALIFIER tquat & tquat::operator+=(tquat const & q) { - this->w += q.w; - this->x += q.x; - this->y += q.y; - this->z += q.z; + this->w += static_cast(q.w); + this->x += static_cast(q.x); + this->y += static_cast(q.y); + this->z += static_cast(q.z); return *this; } template - GLM_FUNC_QUALIFIER tquat & tquat::operator*=(tquat const & q) + template + GLM_FUNC_QUALIFIER tquat & tquat::operator*=(tquat const & r) { tquat const p(*this); + tquat const q(r); this->w = p.w * q.w - p.x * q.x - p.y * q.y - p.z * q.z; this->x = p.w * q.x + p.x * q.w + p.y * q.z - p.z * q.y; @@ -242,23 +271,25 @@ namespace detail return *this; } - template - GLM_FUNC_QUALIFIER tquat & tquat::operator*=(T const & s) + template + template + GLM_FUNC_QUALIFIER tquat & tquat::operator*=(U s) { - this->w *= s; - this->x *= s; - this->y *= s; - this->z *= s; + this->w *= static_cast(s); + this->x *= static_cast(s); + this->y *= static_cast(s); + this->z *= static_cast(s); return *this; } - template - GLM_FUNC_QUALIFIER tquat & tquat::operator/=(T const & s) + template + template + GLM_FUNC_QUALIFIER tquat & tquat::operator/=(U s) { - this->w /= s; - this->x /= s; - this->y /= s; - this->z /= s; + this->w /= static_cast(s); + this->x /= static_cast(s); + this->y /= static_cast(s); + this->z /= static_cast(s); return *this; } diff --git a/glm/gtx/dual_quaternion.hpp b/glm/gtx/dual_quaternion.hpp index 66771f99c..3cb147466 100644 --- a/glm/gtx/dual_quaternion.hpp +++ b/glm/gtx/dual_quaternion.hpp @@ -90,6 +90,7 @@ namespace glm // Implicit basic constructors GLM_FUNC_DECL tdualquat(); + GLM_FUNC_DECL tdualquat(tdualquat const & d); template GLM_FUNC_DECL tdualquat(tdualquat const & d); @@ -116,8 +117,14 @@ namespace glm GLM_FUNC_DECL explicit tdualquat(tmat3x4 const & aug_mat); // Operators - GLM_FUNC_DECL tdualquat & operator*=(T const & s); - GLM_FUNC_DECL tdualquat & operator/=(T const & s); + GLM_FUNC_DECL tdualquat & operator=(tdualquat const & m); + + template + GLM_FUNC_DECL tdualquat & operator=(tdualquat const & m); + template + GLM_FUNC_DECL tdualquat & operator*=(U s); + template + GLM_FUNC_DECL tdualquat & operator/=(U s); }; template diff --git a/glm/gtx/dual_quaternion.inl b/glm/gtx/dual_quaternion.inl index 6fed846fc..8fed08554 100644 --- a/glm/gtx/dual_quaternion.inl +++ b/glm/gtx/dual_quaternion.inl @@ -91,6 +91,12 @@ namespace glm # endif {} + template + GLM_FUNC_QUALIFIER tdualquat::tdualquat(tdualquat const & d) + : real(d.real) + , dual(d.dual) + {} + template template GLM_FUNC_QUALIFIER tdualquat::tdualquat(tdualquat const & d) @@ -150,18 +156,37 @@ namespace glm // tdualquat operators template - GLM_FUNC_QUALIFIER tdualquat & tdualquat::operator*=(T const & s) + GLM_FUNC_QUALIFIER tdualquat & tdualquat::operator=(tdualquat const & q) + { + this->real = q.real; + this->dual = q.dual; + return *this; + } + + template + template + GLM_FUNC_QUALIFIER tdualquat & tdualquat::operator=(tdualquat const & q) + { + this->real = q.real; + this->dual = q.dual; + return *this; + } + + template + template + GLM_FUNC_QUALIFIER tdualquat & tdualquat::operator*=(U s) { - this->real *= s; - this->dual *= s; + this->real *= static_cast(s); + this->dual *= static_cast(s); return *this; } template - GLM_FUNC_QUALIFIER tdualquat & tdualquat::operator/=(T const & s) + template + GLM_FUNC_QUALIFIER tdualquat & tdualquat::operator/=(U s) { - this->real /= s; - this->dual /= s; + this->real /= static_cast(s); + this->dual /= static_cast(s); return *this; }