// 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;
}