From 6f67371bb1b46579ae837d0e0c61ac1b291be743 Mon Sep 17 00:00:00 2001 From: LaG1924 <12997935+LaG1924@users.noreply.github.com> Date: Sat, 13 Jan 2018 07:51:33 +0500 Subject: Directory renamed --- external/include/glm/detail/type_mat4x2.hpp | 177 ++++++++++++++++++++++++++++ 1 file changed, 177 insertions(+) create mode 100644 external/include/glm/detail/type_mat4x2.hpp (limited to 'external/include/glm/detail/type_mat4x2.hpp') diff --git a/external/include/glm/detail/type_mat4x2.hpp b/external/include/glm/detail/type_mat4x2.hpp new file mode 100644 index 0000000..a899d94 --- /dev/null +++ b/external/include/glm/detail/type_mat4x2.hpp @@ -0,0 +1,177 @@ +/// @ref core +/// @file glm/detail/type_mat4x2.hpp + +#pragma once + +#include "../fwd.hpp" +#include "type_vec2.hpp" +#include "type_vec4.hpp" +#include "type_mat.hpp" +#include +#include + +namespace glm +{ + template + struct tmat4x2 + { + typedef tvec2 col_type; + typedef tvec4 row_type; + typedef tmat4x2 type; + typedef tmat2x4 transpose_type; + typedef T value_type; + + private: + col_type value[4]; + + public: + // -- Constructors -- + + GLM_FUNC_DECL tmat4x2() GLM_DEFAULT_CTOR; + GLM_FUNC_DECL tmat4x2(tmat4x2 const & m) GLM_DEFAULT; + template + GLM_FUNC_DECL tmat4x2(tmat4x2 const & m); + + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR explicit tmat4x2(ctor); + GLM_FUNC_DECL explicit tmat4x2(T scalar); + GLM_FUNC_DECL tmat4x2( + T x0, T y0, + T x1, T y1, + T x2, T y2, + T x3, T y3); + GLM_FUNC_DECL tmat4x2( + col_type const & v0, + col_type const & v1, + col_type const & v2, + col_type const & v3); + + // -- Conversions -- + + template < + typename X1, typename Y1, + typename X2, typename Y2, + typename X3, typename Y3, + typename X4, typename Y4> + GLM_FUNC_DECL tmat4x2( + X1 x1, Y1 y1, + X2 x2, Y2 y2, + X3 x3, Y3 y3, + X4 x4, Y4 y4); + + template + GLM_FUNC_DECL tmat4x2( + tvec2 const & v1, + tvec2 const & v2, + tvec2 const & v3, + tvec2 const & v4); + + // -- Matrix conversions -- + + template + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat4x2 const & m); + + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat2x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat3x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat4x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat2x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat3x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat2x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(tmat4x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat4x2(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 tmat4x2 & operator=(tmat4x2 const & m) GLM_DEFAULT; + + template + GLM_FUNC_DECL tmat4x2 & operator=(tmat4x2 const & m); + template + GLM_FUNC_DECL tmat4x2 & operator+=(U s); + template + GLM_FUNC_DECL tmat4x2 & operator+=(tmat4x2 const & m); + template + GLM_FUNC_DECL tmat4x2 & operator-=(U s); + template + GLM_FUNC_DECL tmat4x2 & operator-=(tmat4x2 const & m); + template + GLM_FUNC_DECL tmat4x2 & operator*=(U s); + template + GLM_FUNC_DECL tmat4x2 & operator/=(U s); + + // -- Increment and decrement operators -- + + GLM_FUNC_DECL tmat4x2 & operator++ (); + GLM_FUNC_DECL tmat4x2 & operator-- (); + GLM_FUNC_DECL tmat4x2 operator++(int); + GLM_FUNC_DECL tmat4x2 operator--(int); + }; + + // -- Unary operators -- + + template + GLM_FUNC_DECL tmat4x2 operator+(tmat4x2 const & m); + + template + GLM_FUNC_DECL tmat4x2 operator-(tmat4x2 const & m); + + // -- Binary operators -- + + template + GLM_FUNC_DECL tmat4x2 operator+(tmat4x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat4x2 operator+(tmat4x2 const & m1, tmat4x2 const & m2); + + template + GLM_FUNC_DECL tmat4x2 operator-(tmat4x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat4x2 operator-(tmat4x2 const & m1, tmat4x2 const & m2); + + template + GLM_FUNC_DECL tmat4x2 operator*(tmat4x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat4x2 operator*(T scalar, tmat4x2 const & m); + + template + GLM_FUNC_DECL typename tmat4x2::col_type operator*(tmat4x2 const & m, typename tmat4x2::row_type const & v); + + template + GLM_FUNC_DECL typename tmat4x2::row_type operator*(typename tmat4x2::col_type const & v, tmat4x2 const & m); + + template + GLM_FUNC_DECL tmat2x2 operator*(tmat4x2 const & m1, tmat2x4 const & m2); + + template + GLM_FUNC_DECL tmat3x2 operator*(tmat4x2 const & m1, tmat3x4 const & m2); + + template + GLM_FUNC_DECL tmat4x2 operator*(tmat4x2 const & m1, tmat4x4 const & m2); + + template + GLM_FUNC_DECL tmat4x2 operator/(tmat4x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat4x2 operator/(T scalar, tmat4x2 const & m); + + // -- Boolean operators -- + + template + GLM_FUNC_DECL bool operator==(tmat4x2 const & m1, tmat4x2 const & m2); + + template + GLM_FUNC_DECL bool operator!=(tmat4x2 const & m1, tmat4x2 const & m2); +}//namespace glm + +#ifndef GLM_EXTERNAL_TEMPLATE +#include "type_mat4x2.inl" +#endif -- cgit v1.2.3