Added test for inheritance #650

This commit is contained in:
Christophe Riccio 2017-08-16 18:44:20 +02:00
parent c0df21a398
commit cdb28edcaa

View File

@ -1,5 +1,6 @@
#define GLM_FORCE_ALIGNED
#define GLM_FORCE_SWIZZLE
#include <glm/gtc/epsilon.hpp>
#include <glm/vector_relational.hpp>
#include <glm/vec2.hpp>
#include <glm/vec3.hpp>
@ -33,7 +34,7 @@ enum comp
// return _mm_shuffle_ps(Src, Src, mask<(int(W) << 6) | (int(Z) << 4) | (int(Y) << 2) | (int(X) << 0)>::value);
//}
int test_vec4_ctor()
static int test_vec4_ctor()
{
int Error = 0;
@ -128,7 +129,7 @@ int test_vec4_ctor()
return Error;
}
int test_bvec4_ctor()
static int test_bvec4_ctor()
{
int Error = 0;
@ -148,7 +149,7 @@ int test_bvec4_ctor()
return Error;
}
int test_vec4_operators()
static int test_vec4_operators()
{
int Error = 0;
@ -284,7 +285,7 @@ int test_vec4_operators()
return Error;
}
int test_vec4_equal()
static int test_vec4_equal()
{
int Error = 0;
@ -305,7 +306,7 @@ int test_vec4_equal()
return Error;
}
int test_vec4_size()
static int test_vec4_size()
{
int Error = 0;
@ -330,7 +331,7 @@ int test_vec4_size()
return Error;
}
int test_vec4_swizzle_partial()
static int test_vec4_swizzle_partial()
{
int Error = 0;
@ -367,7 +368,7 @@ int test_vec4_swizzle_partial()
return Error;
}
int test_operator_increment()
static int test_operator_increment()
{
int Error(0);
@ -402,7 +403,7 @@ struct AoS
glm::vec2 D;
};
int test_vec4_perf_AoS(std::size_t Size)
static int test_vec4_perf_AoS(std::size_t Size)
{
int Error(0);
@ -423,7 +424,7 @@ int test_vec4_perf_AoS(std::size_t Size)
return Error;
}
int test_vec4_perf_SoA(std::size_t Size)
static int test_vec4_perf_SoA(std::size_t Size)
{
int Error(0);
@ -475,7 +476,7 @@ namespace heap
glm::vec4 v;
};
int test()
static int test()
{
int Error = 0;
@ -489,7 +490,7 @@ namespace heap
}
}//namespace heap
int test_vec4_simd()
static int test_vec4_simd()
{
int Error = 0;
@ -504,9 +505,34 @@ int test_vec4_simd()
return Error;
}
static int test_inheritance()
{
struct my_vec4 : public glm::vec4
{
my_vec4()
: glm::vec4(76.f, 75.f, 74.f, 73.f)
, data(82)
{}
int data;
};
int Error = 0;
my_vec4 v;
Error += v.data == 82 ? 0 : 1;
Error += glm::epsilonEqual(v.x, 76.f, glm::epsilon<float>()) ? 0 : 1;
Error += glm::epsilonEqual(v.y, 75.f, glm::epsilon<float>()) ? 0 : 1;
Error += glm::epsilonEqual(v.z, 74.f, glm::epsilon<float>()) ? 0 : 1;
Error += glm::epsilonEqual(v.w, 73.f, glm::epsilon<float>()) ? 0 : 1;
return Error;
}
int main()
{
int Error(0);
int Error = 0;
/*
{
@ -565,6 +591,7 @@ int main()
Error += test_vec4_simd();
Error += test_operator_increment();
Error += heap::test();
Error += test_inheritance();
return Error;
}