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_mat2x2.hpp | 183 ++++++++++++++++++++++++++++ 1 file changed, 183 insertions(+) create mode 100644 external/include/glm/detail/type_mat2x2.hpp (limited to 'external/include/glm/detail/type_mat2x2.hpp') diff --git a/external/include/glm/detail/type_mat2x2.hpp b/external/include/glm/detail/type_mat2x2.hpp new file mode 100644 index 0000000..e7fde26 --- /dev/null +++ b/external/include/glm/detail/type_mat2x2.hpp @@ -0,0 +1,183 @@ +/// @ref core +/// @file glm/detail/type_mat2x2.hpp + +#pragma once + +#include "../fwd.hpp" +#include "type_vec2.hpp" +#include "type_mat.hpp" +#include +#include + +namespace glm +{ + template + struct tmat2x2 + { + typedef tvec2 col_type; + typedef tvec2 row_type; + typedef tmat2x2 type; + typedef tmat2x2 transpose_type; + typedef T value_type; + + private: + col_type value[2]; + + public: + // -- Constructors -- + + GLM_FUNC_DECL tmat2x2() GLM_DEFAULT_CTOR; + GLM_FUNC_DECL tmat2x2(tmat2x2 const & m) GLM_DEFAULT; + template + GLM_FUNC_DECL tmat2x2(tmat2x2 const & m); + + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR explicit tmat2x2(ctor); + GLM_FUNC_DECL explicit tmat2x2(T scalar); + GLM_FUNC_DECL tmat2x2( + T const & x1, T const & y1, + T const & x2, T const & y2); + GLM_FUNC_DECL tmat2x2( + col_type const & v1, + col_type const & v2); + + // -- Conversions -- + + template + GLM_FUNC_DECL tmat2x2( + U const & x1, V const & y1, + M const & x2, N const & y2); + + template + GLM_FUNC_DECL tmat2x2( + tvec2 const & v1, + tvec2 const & v2); + + // -- Matrix conversions -- + + template + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat2x2 const & m); + + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat3x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat4x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat2x3 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat3x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat2x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat4x2 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat3x4 const & x); + GLM_FUNC_DECL GLM_EXPLICIT tmat2x2(tmat4x3 const & x); + + // -- Accesses -- + + typedef length_t length_type; + GLM_FUNC_DECL static length_type length(){return 2;} + + 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 tmat2x2 & operator=(tmat2x2 const & v) GLM_DEFAULT; + + template + GLM_FUNC_DECL tmat2x2 & operator=(tmat2x2 const & m); + template + GLM_FUNC_DECL tmat2x2 & operator+=(U s); + template + GLM_FUNC_DECL tmat2x2 & operator+=(tmat2x2 const & m); + template + GLM_FUNC_DECL tmat2x2 & operator-=(U s); + template + GLM_FUNC_DECL tmat2x2 & operator-=(tmat2x2 const & m); + template + GLM_FUNC_DECL tmat2x2 & operator*=(U s); + template + GLM_FUNC_DECL tmat2x2 & operator*=(tmat2x2 const & m); + template + GLM_FUNC_DECL tmat2x2 & operator/=(U s); + template + GLM_FUNC_DECL tmat2x2 & operator/=(tmat2x2 const & m); + + // -- Increment and decrement operators -- + + GLM_FUNC_DECL tmat2x2 & operator++ (); + GLM_FUNC_DECL tmat2x2 & operator-- (); + GLM_FUNC_DECL tmat2x2 operator++(int); + GLM_FUNC_DECL tmat2x2 operator--(int); + }; + + // -- Unary operators -- + + template + GLM_FUNC_DECL tmat2x2 operator+(tmat2x2 const & m); + + template + GLM_FUNC_DECL tmat2x2 operator-(tmat2x2 const & m); + + // -- Binary operators -- + + template + GLM_FUNC_DECL tmat2x2 operator+(tmat2x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat2x2 operator+(T scalar, tmat2x2 const & m); + + template + GLM_FUNC_DECL tmat2x2 operator+(tmat2x2 const & m1, tmat2x2 const & m2); + + template + GLM_FUNC_DECL tmat2x2 operator-(tmat2x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat2x2 operator-(T scalar, tmat2x2 const & m); + + template + GLM_FUNC_DECL tmat2x2 operator-(tmat2x2 const & m1, tmat2x2 const & m2); + + template + GLM_FUNC_DECL tmat2x2 operator*(tmat2x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat2x2 operator*(T scalar, tmat2x2 const & m); + + template + GLM_FUNC_DECL typename tmat2x2::col_type operator*(tmat2x2 const & m, typename tmat2x2::row_type const & v); + + template + GLM_FUNC_DECL typename tmat2x2::row_type operator*(typename tmat2x2::col_type const & v, tmat2x2 const & m); + + template + GLM_FUNC_DECL tmat2x2 operator*(tmat2x2 const & m1, tmat2x2 const & m2); + + template + GLM_FUNC_DECL tmat3x2 operator*(tmat2x2 const & m1, tmat3x2 const & m2); + + template + GLM_FUNC_DECL tmat4x2 operator*(tmat2x2 const & m1, tmat4x2 const & m2); + + template + GLM_FUNC_DECL tmat2x2 operator/(tmat2x2 const & m, T scalar); + + template + GLM_FUNC_DECL tmat2x2 operator/(T scalar, tmat2x2 const & m); + + template + GLM_FUNC_DECL typename tmat2x2::col_type operator/(tmat2x2 const & m, typename tmat2x2::row_type const & v); + + template + GLM_FUNC_DECL typename tmat2x2::row_type operator/(typename tmat2x2::col_type const & v, tmat2x2 const & m); + + template + GLM_FUNC_DECL tmat2x2 operator/(tmat2x2 const & m1, tmat2x2 const & m2); + + // -- Boolean operators -- + + template + GLM_FUNC_DECL bool operator==(tmat2x2 const & m1, tmat2x2 const & m2); + + template + GLM_FUNC_DECL bool operator!=(tmat2x2 const & m1, tmat2x2 const & m2); +} //namespace glm + +#ifndef GLM_EXTERNAL_TEMPLATE +#include "type_mat2x2.inl" +#endif -- cgit v1.2.3