|
|
@@ -3,6 +3,13 @@
|
|
|
|
|
|
#include "compute_vector_relational.hpp"
|
|
|
|
|
|
+// Bug #782: Warning C4701: potentially uninitialized local variable 'Result' used
|
|
|
+#if ((GLM_COMPILER & GLM_COMPILER_VC) && (GLM_COMPILER >= GLM_COMPILER_VC12))
|
|
|
+# define GLM_BUG_VC_INIT (false)
|
|
|
+#else
|
|
|
+# define GLM_BUG_VC_INIT
|
|
|
+#endif
|
|
|
+
|
|
|
namespace glm
|
|
|
{
|
|
|
template<length_t L, typename T, qualifier Q>
|
|
|
@@ -10,7 +17,7 @@ namespace glm
|
|
|
{
|
|
|
assert(x.length() == y.length());
|
|
|
|
|
|
- vec<L, bool, Q> Result;
|
|
|
+ vec<L, bool, Q> Result GLM_BUG_VC_INIT;
|
|
|
for(length_t i = 0; i < x.length(); ++i)
|
|
|
Result[i] = x[i] < y[i];
|
|
|
|
|
|
@@ -22,7 +29,7 @@ namespace glm
|
|
|
{
|
|
|
assert(x.length() == y.length());
|
|
|
|
|
|
- vec<L, bool, Q> Result;
|
|
|
+ vec<L, bool, Q> Result GLM_BUG_VC_INIT;
|
|
|
for(length_t i = 0; i < x.length(); ++i)
|
|
|
Result[i] = x[i] <= y[i];
|
|
|
return Result;
|
|
|
@@ -33,7 +40,7 @@ namespace glm
|
|
|
{
|
|
|
assert(x.length() == y.length());
|
|
|
|
|
|
- vec<L, bool, Q> Result;
|
|
|
+ vec<L, bool, Q> Result GLM_BUG_VC_INIT;
|
|
|
for(length_t i = 0; i < x.length(); ++i)
|
|
|
Result[i] = x[i] > y[i];
|
|
|
return Result;
|
|
|
@@ -44,7 +51,7 @@ namespace glm
|
|
|
{
|
|
|
assert(x.length() == y.length());
|
|
|
|
|
|
- vec<L, bool, Q> Result;
|
|
|
+ vec<L, bool, Q> Result GLM_BUG_VC_INIT;
|
|
|
for(length_t i = 0; i < x.length(); ++i)
|
|
|
Result[i] = x[i] >= y[i];
|
|
|
return Result;
|
|
|
@@ -55,7 +62,7 @@ namespace glm
|
|
|
{
|
|
|
assert(x.length() == y.length());
|
|
|
|
|
|
- vec<L, bool, Q> Result;
|
|
|
+ vec<L, bool, Q> Result GLM_BUG_VC_INIT;
|
|
|
for(length_t i = 0; i < x.length(); ++i)
|
|
|
Result[i] = detail::compute_equal<T, std::numeric_limits<T>::is_iec559>::call(x[i], y[i]);
|
|
|
return Result;
|
|
|
@@ -66,7 +73,7 @@ namespace glm
|
|
|
{
|
|
|
assert(x.length() == y.length());
|
|
|
|
|
|
- vec<L, bool, Q> Result;
|
|
|
+ vec<L, bool, Q> Result GLM_BUG_VC_INIT;
|
|
|
for(length_t i = 0; i < x.length(); ++i)
|
|
|
Result[i] = !detail::compute_equal<T, std::numeric_limits<T>::is_iec559>::call(x[i], y[i]);
|
|
|
return Result;
|