diff options
Diffstat (limited to 'external/include/glm/gtx/matrix_major_storage.inl')
-rw-r--r-- | external/include/glm/gtx/matrix_major_storage.inl | 167 |
1 files changed, 167 insertions, 0 deletions
diff --git a/external/include/glm/gtx/matrix_major_storage.inl b/external/include/glm/gtx/matrix_major_storage.inl new file mode 100644 index 0000000..7097739 --- /dev/null +++ b/external/include/glm/gtx/matrix_major_storage.inl @@ -0,0 +1,167 @@ +/// @ref gtx_matrix_major_storage +/// @file glm/gtx/matrix_major_storage.hpp + +namespace glm +{ + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat2x2<T, P> rowMajor2 + ( + tvec2<T, P> const & v1, + tvec2<T, P> const & v2 + ) + { + tmat2x2<T, P> Result; + Result[0][0] = v1.x; + Result[1][0] = v1.y; + Result[0][1] = v2.x; + Result[1][1] = v2.y; + return Result; + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat2x2<T, P> rowMajor2( + const tmat2x2<T, P>& m) + { + tmat2x2<T, P> Result; + Result[0][0] = m[0][0]; + Result[0][1] = m[1][0]; + Result[1][0] = m[0][1]; + Result[1][1] = m[1][1]; + return Result; + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat3x3<T, P> rowMajor3( + const tvec3<T, P>& v1, + const tvec3<T, P>& v2, + const tvec3<T, P>& v3) + { + tmat3x3<T, P> Result; + Result[0][0] = v1.x; + Result[1][0] = v1.y; + Result[2][0] = v1.z; + Result[0][1] = v2.x; + Result[1][1] = v2.y; + Result[2][1] = v2.z; + Result[0][2] = v3.x; + Result[1][2] = v3.y; + Result[2][2] = v3.z; + return Result; + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat3x3<T, P> rowMajor3( + const tmat3x3<T, P>& m) + { + tmat3x3<T, P> Result; + Result[0][0] = m[0][0]; + Result[0][1] = m[1][0]; + Result[0][2] = m[2][0]; + Result[1][0] = m[0][1]; + Result[1][1] = m[1][1]; + Result[1][2] = m[2][1]; + Result[2][0] = m[0][2]; + Result[2][1] = m[1][2]; + Result[2][2] = m[2][2]; + return Result; + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat4x4<T, P> rowMajor4( + const tvec4<T, P>& v1, + const tvec4<T, P>& v2, + const tvec4<T, P>& v3, + const tvec4<T, P>& v4) + { + tmat4x4<T, P> Result; + Result[0][0] = v1.x; + Result[1][0] = v1.y; + Result[2][0] = v1.z; + Result[3][0] = v1.w; + Result[0][1] = v2.x; + Result[1][1] = v2.y; + Result[2][1] = v2.z; + Result[3][1] = v2.w; + Result[0][2] = v3.x; + Result[1][2] = v3.y; + Result[2][2] = v3.z; + Result[3][2] = v3.w; + Result[0][3] = v4.x; + Result[1][3] = v4.y; + Result[2][3] = v4.z; + Result[3][3] = v4.w; + return Result; + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat4x4<T, P> rowMajor4( + const tmat4x4<T, P>& m) + { + tmat4x4<T, P> Result; + Result[0][0] = m[0][0]; + Result[0][1] = m[1][0]; + Result[0][2] = m[2][0]; + Result[0][3] = m[3][0]; + Result[1][0] = m[0][1]; + Result[1][1] = m[1][1]; + Result[1][2] = m[2][1]; + Result[1][3] = m[3][1]; + Result[2][0] = m[0][2]; + Result[2][1] = m[1][2]; + Result[2][2] = m[2][2]; + Result[2][3] = m[3][2]; + Result[3][0] = m[0][3]; + Result[3][1] = m[1][3]; + Result[3][2] = m[2][3]; + Result[3][3] = m[3][3]; + return Result; + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat2x2<T, P> colMajor2( + const tvec2<T, P>& v1, + const tvec2<T, P>& v2) + { + return tmat2x2<T, P>(v1, v2); + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat2x2<T, P> colMajor2( + const tmat2x2<T, P>& m) + { + return tmat2x2<T, P>(m); + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat3x3<T, P> colMajor3( + const tvec3<T, P>& v1, + const tvec3<T, P>& v2, + const tvec3<T, P>& v3) + { + return tmat3x3<T, P>(v1, v2, v3); + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat3x3<T, P> colMajor3( + const tmat3x3<T, P>& m) + { + return tmat3x3<T, P>(m); + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat4x4<T, P> colMajor4( + const tvec4<T, P>& v1, + const tvec4<T, P>& v2, + const tvec4<T, P>& v3, + const tvec4<T, P>& v4) + { + return tmat4x4<T, P>(v1, v2, v3, v4); + } + + template <typename T, precision P> + GLM_FUNC_QUALIFIER tmat4x4<T, P> colMajor4( + const tmat4x4<T, P>& m) + { + return tmat4x4<T, P>(m); + } +}//namespace glm |