|
|
@@ -7,256 +7,256 @@
|
|
|
// File : test/gtc/type_ptr.cpp
|
|
|
///////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
-#include <glm/glm.hpp>
|
|
|
+#define GLM_FORCE_RADIANS
|
|
|
#include <glm/gtc/type_ptr.hpp>
|
|
|
|
|
|
int test_value_ptr_vec()
|
|
|
{
|
|
|
- int Error = 0;
|
|
|
-
|
|
|
- {
|
|
|
- glm::vec2 v(1.0);
|
|
|
- float * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::vec3 v(1.0);
|
|
|
- float * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::vec4 v(1.0);
|
|
|
- float * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
-
|
|
|
- {
|
|
|
- glm::dvec2 v(1.0);
|
|
|
- double * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::dvec3 v(1.0);
|
|
|
- double * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::dvec4 v(1.0);
|
|
|
- double * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
-
|
|
|
- return Error;
|
|
|
+ int Error = 0;
|
|
|
+
|
|
|
+ {
|
|
|
+ glm::vec2 v(1.0);
|
|
|
+ float * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::vec3 v(1.0);
|
|
|
+ float * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::vec4 v(1.0);
|
|
|
+ float * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ {
|
|
|
+ glm::dvec2 v(1.0);
|
|
|
+ double * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::dvec3 v(1.0);
|
|
|
+ double * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::dvec4 v(1.0);
|
|
|
+ double * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ return Error;
|
|
|
}
|
|
|
|
|
|
int test_value_ptr_vec_const()
|
|
|
{
|
|
|
- int Error = 0;
|
|
|
-
|
|
|
- {
|
|
|
- glm::vec2 const v(1.0);
|
|
|
- float const * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::vec3 const v(1.0);
|
|
|
- float const * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::vec4 const v(1.0);
|
|
|
- float const * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
-
|
|
|
- {
|
|
|
- glm::dvec2 const v(1.0);
|
|
|
- double const * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::dvec3 const v(1.0);
|
|
|
- double const * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::dvec4 const v(1.0);
|
|
|
- double const * p = glm::value_ptr(v);
|
|
|
- Error += p == &v[0] ? 0 : 1;
|
|
|
- }
|
|
|
-
|
|
|
- return Error;
|
|
|
+ int Error = 0;
|
|
|
+
|
|
|
+ {
|
|
|
+ glm::vec2 const v(1.0);
|
|
|
+ float const * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::vec3 const v(1.0);
|
|
|
+ float const * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::vec4 const v(1.0);
|
|
|
+ float const * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ {
|
|
|
+ glm::dvec2 const v(1.0);
|
|
|
+ double const * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::dvec3 const v(1.0);
|
|
|
+ double const * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::dvec4 const v(1.0);
|
|
|
+ double const * p = glm::value_ptr(v);
|
|
|
+ Error += p == &v[0] ? 0 : 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ return Error;
|
|
|
}
|
|
|
|
|
|
int test_value_ptr_mat()
|
|
|
{
|
|
|
- int Error = 0;
|
|
|
-
|
|
|
- {
|
|
|
- glm::mat2x2 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat2x3 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat2x4 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat3x2 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat3x3 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat3x4 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat4x2 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat4x3 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat4x4 m(1.0);
|
|
|
- float * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
-
|
|
|
- return Error;
|
|
|
+ int Error = 0;
|
|
|
+
|
|
|
+ {
|
|
|
+ glm::mat2x2 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat2x3 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat2x4 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat3x2 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat3x3 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat3x4 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat4x2 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat4x3 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat4x4 m(1.0);
|
|
|
+ float * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ return Error;
|
|
|
}
|
|
|
|
|
|
int test_value_ptr_mat_const()
|
|
|
{
|
|
|
- int Error = 0;
|
|
|
-
|
|
|
- {
|
|
|
- glm::mat2x2 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat2x3 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat2x4 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat3x2 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat3x3 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat3x4 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat4x2 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat4x3 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
- {
|
|
|
- glm::mat4x4 const m(1.0);
|
|
|
- float const * p = glm::value_ptr(m);
|
|
|
- Error += p == &m[0][0] ? 0 : 1;
|
|
|
- }
|
|
|
-
|
|
|
- return Error;
|
|
|
+ int Error = 0;
|
|
|
+
|
|
|
+ {
|
|
|
+ glm::mat2x2 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat2x3 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat2x4 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat3x2 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat3x3 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat3x4 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat4x2 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat4x3 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+ {
|
|
|
+ glm::mat4x4 const m(1.0);
|
|
|
+ float const * p = glm::value_ptr(m);
|
|
|
+ Error += p == &m[0][0] ? 0 : 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ return Error;
|
|
|
}
|
|
|
|
|
|
int test_make_pointer_mat()
|
|
|
{
|
|
|
- int Error = 0;
|
|
|
+ int Error = 0;
|
|
|
+
|
|
|
+ float ArrayA[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
+ double ArrayB[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
|
|
|
- float ArrayA[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
- double ArrayB[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
-
|
|
|
- glm::mat2x2 Mat2x2A = glm::make_mat2x2(ArrayA);
|
|
|
- glm::mat2x3 Mat2x3A = glm::make_mat2x3(ArrayA);
|
|
|
- glm::mat2x4 Mat2x4A = glm::make_mat2x4(ArrayA);
|
|
|
- glm::mat3x2 Mat3x2A = glm::make_mat3x2(ArrayA);
|
|
|
- glm::mat3x3 Mat3x3A = glm::make_mat3x3(ArrayA);
|
|
|
- glm::mat3x4 Mat3x4A = glm::make_mat3x4(ArrayA);
|
|
|
- glm::mat4x2 Mat4x2A = glm::make_mat4x2(ArrayA);
|
|
|
- glm::mat4x3 Mat4x3A = glm::make_mat4x3(ArrayA);
|
|
|
- glm::mat4x4 Mat4x4A = glm::make_mat4x4(ArrayA);
|
|
|
-
|
|
|
- glm::dmat2x2 Mat2x2B = glm::make_mat2x2(ArrayB);
|
|
|
- glm::dmat2x3 Mat2x3B = glm::make_mat2x3(ArrayB);
|
|
|
- glm::dmat2x4 Mat2x4B = glm::make_mat2x4(ArrayB);
|
|
|
- glm::dmat3x2 Mat3x2B = glm::make_mat3x2(ArrayB);
|
|
|
- glm::dmat3x3 Mat3x3B = glm::make_mat3x3(ArrayB);
|
|
|
- glm::dmat3x4 Mat3x4B = glm::make_mat3x4(ArrayB);
|
|
|
- glm::dmat4x2 Mat4x2B = glm::make_mat4x2(ArrayB);
|
|
|
- glm::dmat4x3 Mat4x3B = glm::make_mat4x3(ArrayB);
|
|
|
- glm::dmat4x4 Mat4x4B = glm::make_mat4x4(ArrayB);
|
|
|
-
|
|
|
- return Error;
|
|
|
+ glm::mat2x2 Mat2x2A = glm::make_mat2x2(ArrayA);
|
|
|
+ glm::mat2x3 Mat2x3A = glm::make_mat2x3(ArrayA);
|
|
|
+ glm::mat2x4 Mat2x4A = glm::make_mat2x4(ArrayA);
|
|
|
+ glm::mat3x2 Mat3x2A = glm::make_mat3x2(ArrayA);
|
|
|
+ glm::mat3x3 Mat3x3A = glm::make_mat3x3(ArrayA);
|
|
|
+ glm::mat3x4 Mat3x4A = glm::make_mat3x4(ArrayA);
|
|
|
+ glm::mat4x2 Mat4x2A = glm::make_mat4x2(ArrayA);
|
|
|
+ glm::mat4x3 Mat4x3A = glm::make_mat4x3(ArrayA);
|
|
|
+ glm::mat4x4 Mat4x4A = glm::make_mat4x4(ArrayA);
|
|
|
+
|
|
|
+ glm::dmat2x2 Mat2x2B = glm::make_mat2x2(ArrayB);
|
|
|
+ glm::dmat2x3 Mat2x3B = glm::make_mat2x3(ArrayB);
|
|
|
+ glm::dmat2x4 Mat2x4B = glm::make_mat2x4(ArrayB);
|
|
|
+ glm::dmat3x2 Mat3x2B = glm::make_mat3x2(ArrayB);
|
|
|
+ glm::dmat3x3 Mat3x3B = glm::make_mat3x3(ArrayB);
|
|
|
+ glm::dmat3x4 Mat3x4B = glm::make_mat3x4(ArrayB);
|
|
|
+ glm::dmat4x2 Mat4x2B = glm::make_mat4x2(ArrayB);
|
|
|
+ glm::dmat4x3 Mat4x3B = glm::make_mat4x3(ArrayB);
|
|
|
+ glm::dmat4x4 Mat4x4B = glm::make_mat4x4(ArrayB);
|
|
|
+
|
|
|
+ return Error;
|
|
|
}
|
|
|
|
|
|
int test_make_pointer_vec()
|
|
|
{
|
|
|
- int Error = 0;
|
|
|
-
|
|
|
- float ArrayA[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
- int ArrayB[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
- bool ArrayC[] = {true, false, true, false, true, false, true, false, true, false, true, false, true, false, true, false};
|
|
|
-
|
|
|
- glm::vec2 Vec2A = glm::make_vec2(ArrayA);
|
|
|
- glm::vec3 Vec3A = glm::make_vec3(ArrayA);
|
|
|
- glm::vec4 Vec4A = glm::make_vec4(ArrayA);
|
|
|
-
|
|
|
- glm::ivec2 Vec2B = glm::make_vec2(ArrayB);
|
|
|
- glm::ivec3 Vec3B = glm::make_vec3(ArrayB);
|
|
|
- glm::ivec4 Vec4B = glm::make_vec4(ArrayB);
|
|
|
-
|
|
|
- glm::bvec2 Vec2C = glm::make_vec2(ArrayC);
|
|
|
- glm::bvec3 Vec3C = glm::make_vec3(ArrayC);
|
|
|
- glm::bvec4 Vec4C = glm::make_vec4(ArrayC);
|
|
|
-
|
|
|
- return Error;
|
|
|
+ int Error = 0;
|
|
|
+
|
|
|
+ float ArrayA[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
+ int ArrayB[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15};
|
|
|
+ bool ArrayC[] = {true, false, true, false, true, false, true, false, true, false, true, false, true, false, true, false};
|
|
|
+
|
|
|
+ glm::vec2 Vec2A = glm::make_vec2(ArrayA);
|
|
|
+ glm::vec3 Vec3A = glm::make_vec3(ArrayA);
|
|
|
+ glm::vec4 Vec4A = glm::make_vec4(ArrayA);
|
|
|
+
|
|
|
+ glm::ivec2 Vec2B = glm::make_vec2(ArrayB);
|
|
|
+ glm::ivec3 Vec3B = glm::make_vec3(ArrayB);
|
|
|
+ glm::ivec4 Vec4B = glm::make_vec4(ArrayB);
|
|
|
+
|
|
|
+ glm::bvec2 Vec2C = glm::make_vec2(ArrayC);
|
|
|
+ glm::bvec3 Vec3C = glm::make_vec3(ArrayC);
|
|
|
+ glm::bvec4 Vec4C = glm::make_vec4(ArrayC);
|
|
|
+
|
|
|
+ return Error;
|
|
|
}
|
|
|
|
|
|
int main()
|
|
|
{
|
|
|
int Error = 0;
|
|
|
-
|
|
|
- Error += test_make_pointer_vec();
|
|
|
- Error += test_make_pointer_mat();
|
|
|
- Error += test_value_ptr_vec();
|
|
|
- Error += test_value_ptr_vec_const();
|
|
|
- Error += test_value_ptr_mat();
|
|
|
- Error += test_value_ptr_mat_const();
|
|
|
-
|
|
|
+
|
|
|
+ Error += test_make_pointer_vec();
|
|
|
+ Error += test_make_pointer_mat();
|
|
|
+ Error += test_value_ptr_vec();
|
|
|
+ Error += test_value_ptr_vec_const();
|
|
|
+ Error += test_value_ptr_mat();
|
|
|
+ Error += test_value_ptr_mat_const();
|
|
|
+
|
|
|
return Error;
|
|
|
}
|