// atlas_tests.cpp (WFMath/Atlas Message conversion test code)
//
// The WorldForge Project
// Copyright (C) 2001 The WorldForge Project
//
// This program is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
//
// For information about WorldForge and its authors, please contact
// the Worldforge Web Site at http://www.worldforge.org.
// Author: Ron Steinke
// Created: 2001-12-12
#include<Atlas/Message/Element.h>
#include "atlasconv.h"
using namespace WFMath;
template<class C>
void atlas_test(const C& c)
{
// cout << c << std::endl;
Atlas::Message::Element a = c.toAtlas();
C out(a);
// cout << out << std::endl;
// Only match to string precision
assert(Equal(c, out, FloatMax(WFMATH_EPSILON,1e-5)));
}
int main()
{
Point<3> p(1, 0, Sqrt2);
atlas_test(p);
Vector<3> v(1, -1, 4);
atlas_test(v);
Quaternion q(v, 0.7);
atlas_test(q);
AxisBox<3> b1(Point<3>().setToOrigin(), p), b2(p, p + v);
atlas_test(b1);
atlas_test(b2);
return 0;
}
syntax highlighted by Code2HTML, v. 0.9.1