irrlicht/tests/vectorPositionDimension2d.cpp

94 lines
2.5 KiB
C++

// Copyright (C) 2008-2012 Colin MacDonald
// No rights reserved: this software is in the public domain.
/** This test verifies that position2d and vector2d are interchangeable,
and that they can convert from dimension2d */
#include "testUtils.h"
using namespace irr;
using namespace core;
template <class DIMENSION, class VECTOR, class POSITION, class T>
static bool doTest(void)
{
bool result = true;
DIMENSION dimension((T)99.9, (T)99.9);
VECTOR vector(dimension);
POSITION position(vector);
DIMENSION dimension2(vector);
result &= (vector == position);
result &= (vector == dimension); // The conversion should be explicit.
result &= (dimension2 == position);
result &= (position == POSITION((T)99.9, (T)99.9));
assert_log(result);
dimension = (T)2 * position;
result &= (dimension == VECTOR(2 * (T)99.9, 2 * (T)99.9));
assert_log(result);
dimension /= (T)2;
result &= (dimension == POSITION((T)99.9, (T)99.9));
assert_log(result);
dimension += vector;
result &= (dimension == VECTOR(2 * (T)99.9, 2 * (T)99.9));
assert_log(result);
dimension -= position;
result &= (dimension == POSITION((T)99.9, (T)99.9));
assert_log(result);
position = dimension;
result &= (position == VECTOR((T)99.9, (T)99.9));
assert_log(result);
vector += position;
result &= (vector == POSITION(2 * (T)99.9, 2 * (T)99.9));
assert_log(result);
vector -= position;
result &= (vector == dimension);
assert_log(result);
position *= (T)3.5;
result &= (position == VECTOR((T)3.5 * (T)99.9, (T)3.5 * (T)99.9));
assert_log(result);
vector += dimension;
result &= (vector == VECTOR(2 * (T)99.9, 2 * (T)99.9));
assert_log(result);
return result;
}
bool vectorPositionDimension2d(void)
{
bool result = true;
logTestString("vector,position,dimension test with s32\n\n");
result &= doTest<dimension2di, vector2di, position2di, s32>();
if (result)
logTestString("tests passed\n\n");
else
logTestString("\ntests failed\n\n");
logTestString("vector,position,dimension test with f32\n\n");
result &= doTest<dimension2df, vector2df, position2df, f32>();
if (result)
logTestString("tests passed\n\n");
else
logTestString("\ntests failed\n\n");
logTestString("vector,position,dimension test with f64\n\n");
result &= doTest<dimension2d<f64>, vector2d<f64>, position2d<f64>, f64>();
if (result)
logTestString("tests passed\n\n");
else
logTestString("\ntests failed\n\n");
return result;
}