vec_traits_array_test.cpp 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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/vec_traits_array.hpp>
  5. #include <boost/qvm/vec_operations.hpp>
  6. #include <boost/detail/lightweight_test.hpp>
  7. template <class T,class U>
  8. struct same_type;
  9. template <class T>
  10. struct
  11. same_type<T,T>
  12. {
  13. };
  14. template <class T,class P>
  15. void
  16. test_ref_cast( T & v, P * ptr )
  17. {
  18. using namespace boost::qvm;
  19. BOOST_QVM_STATIC_ASSERT(is_vec<T>::value);
  20. BOOST_QVM_STATIC_ASSERT(vec_traits<T>::dim==3);
  21. BOOST_TEST(vec_traits<T>::template read_element<0>(v)==ptr[0]);
  22. BOOST_TEST(vec_traits<T>::template read_element<1>(v)==ptr[1]);
  23. BOOST_TEST(vec_traits<T>::template read_element<2>(v)==ptr[2]);
  24. BOOST_TEST(&vec_traits<T>::template write_element<0>(v)==&ptr[0]);
  25. BOOST_TEST(&vec_traits<T>::template write_element<1>(v)==&ptr[1]);
  26. BOOST_TEST(&vec_traits<T>::template write_element<2>(v)==&ptr[2]);
  27. BOOST_TEST(&v[0]==&ptr[0]);
  28. BOOST_TEST(&v[1]==&ptr[1]);
  29. BOOST_TEST(&v[2]==&ptr[2]);
  30. }
  31. int
  32. main()
  33. {
  34. using namespace boost::qvm;
  35. {
  36. BOOST_QVM_STATIC_ASSERT(is_vec<int[3]>::value);
  37. BOOST_QVM_STATIC_ASSERT(!is_vec<int[3][3]>::value);
  38. BOOST_QVM_STATIC_ASSERT(!is_vec<int[3][3][3]>::value);
  39. BOOST_QVM_STATIC_ASSERT((vec_traits<int[3]>::dim==3));
  40. same_type<vec_traits<int[3]>::scalar_type,int>();
  41. same_type< vec<int,3>, deduce_vec<int[3]>::type >();
  42. same_type< vec<int,3>, deduce_vec<int const[3]>::type >();
  43. int arr[3] = {0,1,2};
  44. BOOST_TEST((vec_traits<int[3]>::read_element<0>(arr)==0));
  45. BOOST_TEST((vec_traits<int[3]>::read_element<1>(arr)==1));
  46. BOOST_TEST((vec_traits<int[3]>::read_element<2>(arr)==2));
  47. BOOST_TEST((vec_traits<int const[3]>::read_element<0>(arr)==0));
  48. BOOST_TEST((vec_traits<int const[3]>::read_element<1>(arr)==1));
  49. BOOST_TEST((vec_traits<int const[3]>::read_element<2>(arr)==2));
  50. BOOST_TEST((vec_traits<int[3]>::read_element_idx(0,arr)==0));
  51. BOOST_TEST((vec_traits<int[3]>::read_element_idx(1,arr)==1));
  52. BOOST_TEST((vec_traits<int[3]>::read_element_idx(2,arr)==2));
  53. BOOST_TEST((vec_traits<int const[3]>::read_element_idx(0,arr)==0));
  54. BOOST_TEST((vec_traits<int const[3]>::read_element_idx(1,arr)==1));
  55. BOOST_TEST((vec_traits<int const[3]>::read_element_idx(2,arr)==2));
  56. BOOST_TEST((&vec_traits<int[3]>::write_element<0>(arr)==&arr[0]));
  57. BOOST_TEST((&vec_traits<int[3]>::write_element<1>(arr)==&arr[1]));
  58. BOOST_TEST((&vec_traits<int[3]>::write_element<2>(arr)==&arr[2]));
  59. BOOST_TEST((&vec_traits<int[3]>::write_element_idx(0,arr)==&arr[0]));
  60. BOOST_TEST((&vec_traits<int[3]>::write_element_idx(1,arr)==&arr[1]));
  61. BOOST_TEST((&vec_traits<int[3]>::write_element_idx(2,arr)==&arr[2]));
  62. }
  63. {
  64. int arr[42] = {0};
  65. int * ptr=arr+5;
  66. ptr[0]=42;
  67. ptr[1]=43;
  68. ptr[2]=44;
  69. test_ref_cast(ptr_vref<3>(ptr),ptr);
  70. int v[3] = {1,1,1};
  71. ptr_vref<3>(ptr) += vref(v);
  72. BOOST_TEST(ptr[0]==43);
  73. BOOST_TEST(ptr[1]==44);
  74. BOOST_TEST(ptr[2]==45);
  75. }
  76. return boost::report_errors();
  77. }