From c568f0a8c9f0aef00c770b494ee1ff3a89ab48de Mon Sep 17 00:00:00 2001 From: rtk0c Date: Sun, 22 May 2022 01:08:24 -0700 Subject: Changeset: 35 Fix missing sources in git submodules after migration to PlasticSCM --- 3rdparty/glm/source/test/gtc/gtc_epsilon.cpp | 78 ++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 3rdparty/glm/source/test/gtc/gtc_epsilon.cpp (limited to '3rdparty/glm/source/test/gtc/gtc_epsilon.cpp') diff --git a/3rdparty/glm/source/test/gtc/gtc_epsilon.cpp b/3rdparty/glm/source/test/gtc/gtc_epsilon.cpp new file mode 100644 index 0000000..f0e6c8a --- /dev/null +++ b/3rdparty/glm/source/test/gtc/gtc_epsilon.cpp @@ -0,0 +1,78 @@ +#include +#include +#include +#include + +int test_defined() +{ + glm::epsilonEqual(glm::vec2(), glm::vec2(), glm::vec2()); + glm::epsilonEqual(glm::vec3(), glm::vec3(), glm::vec3()); + glm::epsilonEqual(glm::vec4(), glm::vec4(), glm::vec4()); + + glm::epsilonNotEqual(glm::vec2(), glm::vec2(), glm::vec2()); + glm::epsilonNotEqual(glm::vec3(), glm::vec3(), glm::vec3()); + glm::epsilonNotEqual(glm::vec4(), glm::vec4(), glm::vec4()); + + glm::epsilonEqual(glm::vec2(), glm::vec2(), 0.0f); + glm::epsilonEqual(glm::vec3(), glm::vec3(), 0.0f); + glm::epsilonEqual(glm::vec4(), glm::vec4(), 0.0f); + glm::epsilonEqual(glm::quat(), glm::quat(), 0.0f); + + glm::epsilonNotEqual(glm::vec2(), glm::vec2(), 0.0f); + glm::epsilonNotEqual(glm::vec3(), glm::vec3(), 0.0f); + glm::epsilonNotEqual(glm::vec4(), glm::vec4(), 0.0f); + glm::epsilonNotEqual(glm::quat(), glm::quat(), 0.0f); + + return 0; +} + +template +int test_equal() +{ + int Error(0); + + { + T A = glm::epsilon(); + T B = glm::epsilon(); + Error += glm::epsilonEqual(A, B, glm::epsilon() * T(2)) ? 0 : 1; + } + + { + T A(0); + T B = static_cast(0) + glm::epsilon(); + Error += glm::epsilonEqual(A, B, glm::epsilon() * T(2)) ? 0 : 1; + } + + { + T A(0); + T B = static_cast(0) - glm::epsilon(); + Error += glm::epsilonEqual(A, B, glm::epsilon() * T(2)) ? 0 : 1; + } + + { + T A = static_cast(0) + glm::epsilon(); + T B = static_cast(0); + Error += glm::epsilonEqual(A, B, glm::epsilon() * T(2)) ? 0 : 1; + } + + { + T A = static_cast(0) - glm::epsilon(); + T B = static_cast(0); + Error += glm::epsilonEqual(A, B, glm::epsilon() * T(2)) ? 0 : 1; + } + + return Error; +} + +int main() +{ + int Error(0); + + Error += test_defined(); + Error += test_equal(); + Error += test_equal(); + + return Error; +} + + -- cgit v1.2.3-70-g09d2