From e62817b8252974b8a98393275874ee303840bf13 Mon Sep 17 00:00:00 2001 From: LaG1924 <12997935+LaG1924@users.noreply.github.com> Date: Fri, 12 May 2017 18:49:50 +0500 Subject: 2017-05-12 --- depedencies/include/glm/detail/type_mat4x3.hpp | 177 +++++++++++++++++++++++++ 1 file changed, 177 insertions(+) create mode 100644 depedencies/include/glm/detail/type_mat4x3.hpp (limited to 'depedencies/include/glm/detail/type_mat4x3.hpp') diff --git a/depedencies/include/glm/detail/type_mat4x3.hpp b/depedencies/include/glm/detail/type_mat4x3.hpp new file mode 100644 index 0000000..c696735 --- /dev/null +++ b/depedencies/include/glm/detail/type_mat4x3.hpp @@ -0,0 +1,177 @@ +/// @ref core +/// @file glm/detail/type_mat4x3.hpp + +#pragma once + +#include "../fwd.hpp" +#include "type_vec3.hpp" +#include "type_vec4.hpp" +#include "type_mat.hpp" +#include +#include + +namespace glm +{ + template + struct tmat4x3 + { + typedef tvec3 col_type; + typedef tvec4 row_type; + typedef tmat4x3 type; + typedef tmat3x4 transpose_type; + typedef T value_type; + + private: + col_type value[4]; + + public: + // -- Constructors -- + + GLM_FUNC_DECL tmat4x3() GLM_DEFAULT_CTOR; + GLM_FUNC_DECL tmat4x3(tmat4x3 const & m) GLM_DEFAULT; + template + GLM_FUNC_DECL tmat4x3(tmat4x3 const & m); + + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR explicit tmat4x3(ctor); + GLM_FUNC_DECL explicit tmat4x3(T const & x); + GLM_FUNC_DECL tmat4x3( + T const & x0, T const & y0, T const & z0, + T const & x1, T const & y1, T const & z1, + T const & x2, T const & y2, T const & z2, + T const & x3, T const & y3, T const & z3); + GLM_FUNC_DECL tmat4x3( + col_type const & v0, + col_type const & v1, + col_type const & v2, + col_type const & v3); + + // -- Conversions -- + + template < + typename X1, typename Y1, typename Z1, + typename X2, typename Y2, typename Z2, + typename X3, typename Y3, typename Z3, + typename X4, typename Y4, typename Z4> + GLM_FUNC_DECL tmat4x3( + X1 const & x1, Y1 const & y1, Z1 const & z1, + X2 const & x2, Y2 const & y2, Z2 const & z2, + X3 const & x3, Y3 const & y3, Z3 const & z3, + X4 const & x4, Y4 const & y4, Z4 const & z4); + + template + GLM_FUNC_DECL tmat4x3( + tvec3 const & v1, + tvec3 const & v2, + tvec3 const & v3, + tvec3 const & v4); + + // -- Matrix conversions -- + + template + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat4x3 const & m); + + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat2x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat3x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat4x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat2x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat3x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat2x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat4x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x3(tmat3x4 const & x); + + // -- Accesses -- + + typedef length_t length_type; + GLM_FUNC_DECL static length_type length(){return 4;} + + GLM_FUNC_DECL col_type & operator[](length_type i); + GLM_FUNC_DECL col_type const & operator[](length_type i) const; + + // -- Unary arithmetic operators -- + + GLM_FUNC_DECL tmat4x3 & operator=(tmat4x3 const & m) GLM_DEFAULT; + + template + GLM_FUNC_DECL tmat4x3 & operator=(tmat4x3 const & m); + template + GLM_FUNC_DECL tmat4x3 & operator+=(U s); + template + GLM_FUNC_DECL tmat4x3 & operator+=(tmat4x3 const & m); + template + GLM_FUNC_DECL tmat4x3 & operator-=(U s); + template + GLM_FUNC_DECL tmat4x3 & operator-=(tmat4x3 const & m); + template + GLM_FUNC_DECL tmat4x3 & operator*=(U s); + template + GLM_FUNC_DECL tmat4x3 & operator/=(U s); + + // -- Increment and decrement operators -- + + GLM_FUNC_DECL tmat4x3 & operator++(); + GLM_FUNC_DECL tmat4x3 & operator--(); + GLM_FUNC_DECL tmat4x3 operator++(int); + GLM_FUNC_DECL tmat4x3 operator--(int); + }; + + // -- Unary operators -- + + template + GLM_FUNC_DECL tmat4x3 operator+(tmat4x3 const & m); + + template + GLM_FUNC_DECL tmat4x3 operator-(tmat4x3 const & m); + + // -- Binary operators -- + + template + GLM_FUNC_DECL tmat4x3 operator+(tmat4x3 const & m, T const & s); + + template + GLM_FUNC_DECL tmat4x3 operator+(tmat4x3 const & m1, tmat4x3 const & m2); + + template + GLM_FUNC_DECL tmat4x3 operator-(tmat4x3 const & m, T const & s); + + template + GLM_FUNC_DECL tmat4x3 operator-(tmat4x3 const & m1, tmat4x3 const & m2); + + template + GLM_FUNC_DECL tmat4x3 operator*(tmat4x3 const & m, T const & s); + + template + GLM_FUNC_DECL tmat4x3 operator*(T const & s, tmat4x3 const & m); + + template + GLM_FUNC_DECL typename tmat4x3::col_type operator*(tmat4x3 const & m, typename tmat4x3::row_type const & v); + + template + GLM_FUNC_DECL typename tmat4x3::row_type operator*(typename tmat4x3::col_type const & v, tmat4x3 const & m); + + template + GLM_FUNC_DECL tmat2x3 operator*(tmat4x3 const & m1, tmat2x4 const & m2); + + template + GLM_FUNC_DECL tmat3x3 operator*(tmat4x3 const & m1, tmat3x4 const & m2); + + template + GLM_FUNC_DECL tmat4x3 operator*(tmat4x3 const & m1, tmat4x4 const & m2); + + template + GLM_FUNC_DECL tmat4x3 operator/(tmat4x3 const & m, T const & s); + + template + GLM_FUNC_DECL tmat4x3 operator/(T const & s, tmat4x3 const & m); + + // -- Boolean operators -- + + template + GLM_FUNC_DECL bool operator==(tmat4x3 const & m1, tmat4x3 const & m2); + + template + GLM_FUNC_DECL bool operator!=(tmat4x3 const & m1, tmat4x3 const & m2); +}//namespace glm + +#ifndef GLM_EXTERNAL_TEMPLATE +#include "type_mat4x3.inl" +#endif //GLM_EXTERNAL_TEMPLATE -- cgit v1.2.3