diff options
author | LaG1924 <lag1924@gmail.com> | 2021-06-07 04:56:57 +0200 |
---|---|---|
committer | LaG1924 <lag1924@gmail.com> | 2021-06-07 04:56:57 +0200 |
commit | 83889ba33dad2743eeb2a79102a1117ec9220025 (patch) | |
tree | 7e15713639a4e0c12f1a06e467dd0b3d79070983 /external/include/glm/detail/type_gentype.inl | |
parent | Replaced find_package with CPMAddPackage for more libraries (diff) | |
download | AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.tar AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.tar.gz AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.tar.bz2 AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.tar.lz AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.tar.xz AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.tar.zst AltCraft-83889ba33dad2743eeb2a79102a1117ec9220025.zip |
Diffstat (limited to 'external/include/glm/detail/type_gentype.inl')
-rw-r--r-- | external/include/glm/detail/type_gentype.inl | 341 |
1 files changed, 0 insertions, 341 deletions
diff --git a/external/include/glm/detail/type_gentype.inl b/external/include/glm/detail/type_gentype.inl deleted file mode 100644 index 60ffa9a..0000000 --- a/external/include/glm/detail/type_gentype.inl +++ /dev/null @@ -1,341 +0,0 @@ -/// @ref core -/// @file glm/detail/type_gentype.inl - -namespace glm{ -namespace detail{ - -///////////////////////////////// -// Static functions - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::size_type base<vT, cT, rT, pT>::col_size() -{ - return cT; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::size_type base<vT, cT, rT, pT>::row_size() -{ - return rT; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::size_type base<vT, cT, rT, pT>::value_size() -{ - return rT * cT; -} - -template<typename vT, uint cT, uint rT, profile pT> -bool base<vT, cT, rT, pT>::is_scalar() -{ - return rT == 1 && cT == 1; -} - -template<typename vT, uint cT, uint rT, profile pT> -bool base<vT, cT, rT, pT>::is_vector() -{ - return rT == 1; -} - -template<typename vT, uint cT, uint rT, profile pT> -bool base<vT, cT, rT, pT>::is_matrix() -{ - return rT != 1; -} - -///////////////////////////////// -// Constructor - -template<typename vT, uint cT, uint rT, profile pT> -base<vT, cT, rT, pT>::base() -{ - memset(&this->value, 0, cT * rT * sizeof(vT)); -} - -template<typename vT, uint cT, uint rT, profile pT> -base<vT, cT, rT, pT>::base -( - typename base<vT, cT, rT, pT>::class_type const& m -) -{ - for - ( - typename genType<vT, cT, rT, pT>::size_type i = typename base<vT, cT, rT, pT>::size_type(0); - i < base<vT, cT, rT, pT>::col_size(); - ++i - ) - { - this->value[i] = m[i]; - } -} - -template<typename vT, uint cT, uint rT, profile pT> -base<vT, cT, rT, pT>::base -( - typename base<vT, cT, rT, pT>::T const& x -) -{ - if(rT == 1) // vector - { - for - ( - typename base<vT, cT, rT, pT>::size_type i = typename base<vT, cT, rT, pT>::size_type(0); - i < base<vT, cT, rT, pT>::col_size(); - ++i - ) - { - this->value[i][rT] = x; - } - } - else // matrix - { - memset(&this->value, 0, cT * rT * sizeof(vT)); - - typename base<vT, cT, rT, pT>::size_type stop = cT < rT ? cT : rT; - - for - ( - typename base<vT, cT, rT, pT>::size_type i = typename base<vT, cT, rT, pT>::size_type(0); - i < stop; - ++i - ) - { - this->value[i][i] = x; - } - } -} - -template<typename vT, uint cT, uint rT, profile pT> -base<vT, cT, rT, pT>::base -( - typename base<vT, cT, rT, pT>::value_type const * const x -) -{ - memcpy(&this->value, &x.value, cT * rT * sizeof(vT)); -} - -template<typename vT, uint cT, uint rT, profile pT> -base<vT, cT, rT, pT>::base -( - typename base<vT, cT, rT, pT>::col_type const * const x -) -{ - for - ( - typename base<vT, cT, rT, pT>::size_type i = typename base<vT, cT, rT, pT>::size_type(0); - i < base<vT, cT, rT, pT>::col_size(); - ++i - ) - { - this->value[i] = x[i]; - } -} - -template<typename vT, uint cT, uint rT, profile pT> -template<typename vU, uint cU, uint rU, profile pU> -base<vT, cT, rT, pT>::base -( - base<vU, cU, rU, pU> const& m -) -{ - for - ( - typename base<vT, cT, rT, pT>::size_type i = typename base<vT, cT, rT, pT>::size_type(0); - i < base<vT, cT, rT, pT>::col_size(); - ++i - ) - { - this->value[i] = base<vT, cT, rT, pT>(m[i]); - } -} - -////////////////////////////////////// -// Accesses - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::col_type& base<vT, cT, rT, pT>::operator[] -( - typename base<vT, cT, rT, pT>::size_type i -) -{ - return this->value[i]; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::col_type const& base<vT, cT, rT, pT>::operator[] -( - typename base<vT, cT, rT, pT>::size_type i -) const -{ - return this->value[i]; -} - -////////////////////////////////////// -// Unary updatable operators - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator= -( - typename base<vT, cT, rT, pT>::class_type const& x -) -{ - memcpy(&this->value, &x.value, cT * rT * sizeof(vT)); - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator+= -( - typename base<vT, cT, rT, pT>::T const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] += x; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator+= -( - typename base<vT, cT, rT, pT>::class_type const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] += x[j][i]; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator-= -( - typename base<vT, cT, rT, pT>::T const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] -= x; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator-= -( - typename base<vT, cT, rT, pT>::class_type const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] -= x[j][i]; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator*= -( - typename base<vT, cT, rT, pT>::T const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] *= x; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator*= -( - typename base<vT, cT, rT, pT>::class_type const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] *= x[j][i]; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator/= -( - typename base<vT, cT, rT, pT>::T const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] /= x; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator/= -( - typename base<vT, cT, rT, pT>::class_type const& x -) -{ - typename base<vT, cT, rT, pT>::size_type stop_col = x.col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = x.row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - this->value[j][i] /= x[j][i]; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator++ () -{ - typename base<vT, cT, rT, pT>::size_type stop_col = col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - ++this->value[j][i]; - - return *this; -} - -template<typename vT, uint cT, uint rT, profile pT> -typename base<vT, cT, rT, pT>::class_type& base<vT, cT, rT, pT>::operator-- () -{ - typename base<vT, cT, rT, pT>::size_type stop_col = col_size(); - typename base<vT, cT, rT, pT>::size_type stop_row = row_size(); - - for(typename base<vT, cT, rT, pT>::size_type j = 0; j < stop_col; ++j) - for(typename base<vT, cT, rT, pT>::size_type i = 0; i < stop_row; ++i) - --this->value[j][i]; - - return *this; -} - -} //namespace detail -} //namespace glm |