to_string_test.cpp 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. //Copyright (c) 2008-2016 Emil Dotchevski and Reverge Studios, Inc.
  2. //Distributed under the Boost Software License, Version 1.0. (See accompanying
  3. //file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  4. #include <boost/qvm/to_string.hpp>
  5. #include <boost/qvm/quat_operations.hpp>
  6. #include <boost/qvm/vec_operations.hpp>
  7. #include <boost/qvm/mat_operations.hpp>
  8. #include "test_qvm_matrix.hpp"
  9. #include "test_qvm_quaternion.hpp"
  10. #include "test_qvm_vector.hpp"
  11. namespace
  12. {
  13. template <int Rows,int Cols>
  14. void
  15. test_matrix( std::string const & gold )
  16. {
  17. using namespace boost::qvm::sfinae;
  18. test_qvm::matrix<M1,Rows,Cols,int> const x(42,1);
  19. std::string s=to_string(x);
  20. BOOST_TEST(s==gold);
  21. }
  22. template <int Dim>
  23. void
  24. test_vector( std::string const & gold )
  25. {
  26. using namespace boost::qvm::sfinae;
  27. test_qvm::vector<V1,Dim,int> const x(42,1);
  28. std::string s=to_string(x);
  29. BOOST_TEST(s==gold);
  30. }
  31. void
  32. test_quaternion( std::string const & gold )
  33. {
  34. using namespace boost::qvm::sfinae;
  35. test_qvm::quaternion<Q1,int> const x(42,1);
  36. std::string s=to_string(x);
  37. BOOST_TEST(s==gold);
  38. }
  39. }
  40. int
  41. main()
  42. {
  43. test_matrix<1,2>("((42,43))");
  44. test_matrix<2,1>("((42)(43))");
  45. test_matrix<2,2>("((42,43)(44,45))");
  46. test_matrix<1,3>("((42,43,44))");
  47. test_matrix<3,1>("((42)(43)(44))");
  48. test_matrix<3,3>("((42,43,44)(45,46,47)(48,49,50))");
  49. test_matrix<1,4>("((42,43,44,45))");
  50. test_matrix<4,1>("((42)(43)(44)(45))");
  51. test_matrix<4,4>("((42,43,44,45)(46,47,48,49)(50,51,52,53)(54,55,56,57))");
  52. test_matrix<1,5>("((42,43,44,45,46))");
  53. test_matrix<5,1>("((42)(43)(44)(45)(46))");
  54. test_matrix<5,5>("((42,43,44,45,46)(47,48,49,50,51)(52,53,54,55,56)(57,58,59,60,61)(62,63,64,65,66))");
  55. test_vector<2>("(42,43)");
  56. test_vector<3>("(42,43,44)");
  57. test_vector<4>("(42,43,44,45)");
  58. test_vector<5>("(42,43,44,45,46)");
  59. test_quaternion("(42,43,44,45)");
  60. return boost::report_errors();
  61. }