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_vec2.hpp | 388 +++++++++++++++++++++++++++ 1 file changed, 388 insertions(+) create mode 100644 depedencies/include/glm/detail/type_vec2.hpp (limited to 'depedencies/include/glm/detail/type_vec2.hpp') diff --git a/depedencies/include/glm/detail/type_vec2.hpp b/depedencies/include/glm/detail/type_vec2.hpp new file mode 100644 index 0000000..a9af32e --- /dev/null +++ b/depedencies/include/glm/detail/type_vec2.hpp @@ -0,0 +1,388 @@ +/// @ref core +/// @file glm/detail/type_vec2.hpp + +#pragma once + +#include "type_vec.hpp" +#if GLM_SWIZZLE == GLM_SWIZZLE_ENABLED +# if GLM_HAS_UNRESTRICTED_UNIONS +# include "_swizzle.hpp" +# else +# include "_swizzle_func.hpp" +# endif +#endif //GLM_SWIZZLE +#include + +namespace glm +{ + template + struct tvec2 + { + // -- Implementation detail -- + + typedef T value_type; + typedef tvec2 type; + typedef tvec2 bool_type; + + // -- Data -- + +# if GLM_HAS_ONLY_XYZW + T x, y; + +# elif GLM_HAS_ALIGNED_TYPE +# if GLM_COMPILER & GLM_COMPILER_GCC +# pragma GCC diagnostic push +# pragma GCC diagnostic ignored "-Wpedantic" +# endif +# if GLM_COMPILER & GLM_COMPILER_CLANG +# pragma clang diagnostic push +# pragma clang diagnostic ignored "-Wgnu-anonymous-struct" +# pragma clang diagnostic ignored "-Wnested-anon-types" +# endif + + union + { + struct{ T x, y; }; + struct{ T r, g; }; + struct{ T s, t; }; + +# if GLM_SWIZZLE == GLM_SWIZZLE_ENABLED + _GLM_SWIZZLE2_2_MEMBERS(T, P, glm::tvec2, x, y) + _GLM_SWIZZLE2_2_MEMBERS(T, P, glm::tvec2, r, g) + _GLM_SWIZZLE2_2_MEMBERS(T, P, glm::tvec2, s, t) + _GLM_SWIZZLE2_3_MEMBERS(T, P, glm::tvec3, x, y) + _GLM_SWIZZLE2_3_MEMBERS(T, P, glm::tvec3, r, g) + _GLM_SWIZZLE2_3_MEMBERS(T, P, glm::tvec3, s, t) + _GLM_SWIZZLE2_4_MEMBERS(T, P, glm::tvec4, x, y) + _GLM_SWIZZLE2_4_MEMBERS(T, P, glm::tvec4, r, g) + _GLM_SWIZZLE2_4_MEMBERS(T, P, glm::tvec4, s, t) +# endif//GLM_SWIZZLE + + }; + +# if GLM_COMPILER & GLM_COMPILER_CLANG +# pragma clang diagnostic pop +# endif +# if GLM_COMPILER & GLM_COMPILER_GCC +# pragma GCC diagnostic pop +# endif +# else + union {T x, r, s;}; + union {T y, g, t;}; + +# if GLM_SWIZZLE == GLM_SWIZZLE_ENABLED + GLM_SWIZZLE_GEN_VEC_FROM_VEC2(T, P, tvec2, tvec2, tvec3, tvec4) +# endif//GLM_SWIZZLE +# endif + + // -- Component accesses -- + + /// Return the count of components of the vector + typedef length_t length_type; + GLM_FUNC_DECL static length_type length(){return 2;} + + GLM_FUNC_DECL T & operator[](length_type i); + GLM_FUNC_DECL T const & operator[](length_type i) const; + + // -- Implicit basic constructors -- + + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR tvec2() GLM_DEFAULT_CTOR; + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR tvec2(tvec2 const& v) GLM_DEFAULT; + template + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR tvec2(tvec2 const& v); + + // -- Explicit basic constructors -- + + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR explicit tvec2(ctor); + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR explicit tvec2(T scalar); + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR tvec2(T s1, T s2); + + // -- Conversion constructors -- + + /// Explicit converions (From section 5.4.1 Conversion and scalar constructors of GLSL 1.30.08 specification) + template + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR tvec2(A x, B y); + template + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR tvec2(tvec1 const & v1, tvec1 const & v2); + + // -- Conversion vector constructors -- + + /// Explicit conversions (From section 5.4.1 Conversion and scalar constructors of GLSL 1.30.08 specification) + template + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR GLM_EXPLICIT tvec2(tvec3 const & v); + /// Explicit conversions (From section 5.4.1 Conversion and scalar constructors of GLSL 1.30.08 specification) + template + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR GLM_EXPLICIT tvec2(tvec4 const & v); + + /// Explicit conversions (From section 5.4.1 Conversion and scalar constructors of GLSL 1.30.08 specification) + template + GLM_FUNC_DECL GLM_CONSTEXPR_CTOR GLM_EXPLICIT tvec2(tvec2 const & v); + + // -- Swizzle constructors -- +# if GLM_HAS_UNRESTRICTED_UNIONS && (GLM_SWIZZLE == GLM_SWIZZLE_ENABLED) + template + GLM_FUNC_DECL tvec2(detail::_swizzle<2, T, P, glm::tvec2, E0, E1,-1,-2> const& that) + { + *this = that(); + } +# endif// GLM_HAS_UNRESTRICTED_UNIONS && (GLM_SWIZZLE == GLM_SWIZZLE_ENABLED) + + // -- Unary arithmetic operators -- + + GLM_FUNC_DECL tvec2& operator=(tvec2 const & v) GLM_DEFAULT; + + template + GLM_FUNC_DECL tvec2& operator=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2& operator+=(U scalar); + template + GLM_FUNC_DECL tvec2& operator+=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2& operator+=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2& operator-=(U scalar); + template + GLM_FUNC_DECL tvec2& operator-=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2& operator-=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2& operator*=(U scalar); + template + GLM_FUNC_DECL tvec2& operator*=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2& operator*=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2& operator/=(U scalar); + template + GLM_FUNC_DECL tvec2& operator/=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2& operator/=(tvec2 const & v); + + // -- Increment and decrement operators -- + + GLM_FUNC_DECL tvec2 & operator++(); + GLM_FUNC_DECL tvec2 & operator--(); + GLM_FUNC_DECL tvec2 operator++(int); + GLM_FUNC_DECL tvec2 operator--(int); + + // -- Unary bit operators -- + + template + GLM_FUNC_DECL tvec2 & operator%=(U scalar); + template + GLM_FUNC_DECL tvec2 & operator%=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2 & operator%=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2 & operator&=(U scalar); + template + GLM_FUNC_DECL tvec2 & operator&=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2 & operator&=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2 & operator|=(U scalar); + template + GLM_FUNC_DECL tvec2 & operator|=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2 & operator|=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2 & operator^=(U scalar); + template + GLM_FUNC_DECL tvec2 & operator^=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2 & operator^=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2 & operator<<=(U scalar); + template + GLM_FUNC_DECL tvec2 & operator<<=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2 & operator<<=(tvec2 const & v); + template + GLM_FUNC_DECL tvec2 & operator>>=(U scalar); + template + GLM_FUNC_DECL tvec2 & operator>>=(tvec1 const & v); + template + GLM_FUNC_DECL tvec2 & operator>>=(tvec2 const & v); + }; + + // -- Unary operators -- + + template + GLM_FUNC_DECL tvec2 operator+(tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator-(tvec2 const & v); + + // -- Binary operators -- + + template + GLM_FUNC_DECL tvec2 operator+(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator+(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator+(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator+(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator+(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator-(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator-(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator-(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator-(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator-(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator*(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator*(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator*(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator*(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator*(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator/(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator/(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator/(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator/(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator/(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator%(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator%(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator%(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator%(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator%(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator&(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator&(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator&(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator&(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator&(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator|(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator|(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator|(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator|(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator|(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator^(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator^(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator^(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator^(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator^(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator<<(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator<<(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator<<(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator<<(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator<<(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator>>(tvec2 const & v, T scalar); + + template + GLM_FUNC_DECL tvec2 operator>>(tvec2 const & v1, tvec1 const & v2); + + template + GLM_FUNC_DECL tvec2 operator>>(T scalar, tvec2 const & v); + + template + GLM_FUNC_DECL tvec2 operator>>(tvec1 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator>>(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator~(tvec2 const & v); + + // -- Boolean operators -- + + template + GLM_FUNC_DECL bool operator==(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL bool operator!=(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator&&(tvec2 const & v1, tvec2 const & v2); + + template + GLM_FUNC_DECL tvec2 operator||(tvec2 const & v1, tvec2 const & v2); +}//namespace glm + +#ifndef GLM_EXTERNAL_TEMPLATE +#include "type_vec2.inl" +#endif//GLM_EXTERNAL_TEMPLATE -- cgit v1.2.3