//Copyright (c) 2008-2016 Emil Dotchevski and Reverge Studios, Inc. //Distributed under the Boost Software License, Version 1.0. (See accompanying //file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) #ifdef BOOST_QVM_TEST_SINGLE_HEADER # include BOOST_QVM_TEST_SINGLE_HEADER #else # include #endif #include #include template struct same_type; template struct same_type { }; template void test_ref_cast( T & v, P * ptr ) { using namespace boost::qvm; BOOST_QVM_STATIC_ASSERT(is_vec::value); BOOST_QVM_STATIC_ASSERT(vec_traits::dim==3); BOOST_TEST(vec_traits::template read_element<0>(v)==ptr[0]); BOOST_TEST(vec_traits::template read_element<1>(v)==ptr[1]); BOOST_TEST(vec_traits::template read_element<2>(v)==ptr[2]); BOOST_TEST(&vec_traits::template write_element<0>(v)==&ptr[0]); BOOST_TEST(&vec_traits::template write_element<1>(v)==&ptr[1]); BOOST_TEST(&vec_traits::template write_element<2>(v)==&ptr[2]); BOOST_TEST(&v[0]==&ptr[0]); BOOST_TEST(&v[1]==&ptr[1]); BOOST_TEST(&v[2]==&ptr[2]); } int main() { using namespace boost::qvm; { BOOST_QVM_STATIC_ASSERT(is_vec::value); BOOST_QVM_STATIC_ASSERT(!is_vec::value); BOOST_QVM_STATIC_ASSERT(!is_vec::value); BOOST_QVM_STATIC_ASSERT((vec_traits::dim==3)); same_type::scalar_type,int>(); same_type< vec, deduce_vec::type >(); same_type< vec, deduce_vec::type >(); int arr[3] = {0,1,2}; BOOST_TEST((vec_traits::read_element<0>(arr)==0)); BOOST_TEST((vec_traits::read_element<1>(arr)==1)); BOOST_TEST((vec_traits::read_element<2>(arr)==2)); BOOST_TEST((vec_traits::read_element<0>(arr)==0)); BOOST_TEST((vec_traits::read_element<1>(arr)==1)); BOOST_TEST((vec_traits::read_element<2>(arr)==2)); BOOST_TEST((vec_traits::read_element_idx(0,arr)==0)); BOOST_TEST((vec_traits::read_element_idx(1,arr)==1)); BOOST_TEST((vec_traits::read_element_idx(2,arr)==2)); BOOST_TEST((vec_traits::read_element_idx(0,arr)==0)); BOOST_TEST((vec_traits::read_element_idx(1,arr)==1)); BOOST_TEST((vec_traits::read_element_idx(2,arr)==2)); BOOST_TEST((&vec_traits::write_element<0>(arr)==&arr[0])); BOOST_TEST((&vec_traits::write_element<1>(arr)==&arr[1])); BOOST_TEST((&vec_traits::write_element<2>(arr)==&arr[2])); BOOST_TEST((&vec_traits::write_element_idx(0,arr)==&arr[0])); BOOST_TEST((&vec_traits::write_element_idx(1,arr)==&arr[1])); BOOST_TEST((&vec_traits::write_element_idx(2,arr)==&arr[2])); } { int arr[42] = {0}; int * ptr=arr+5; ptr[0]=42; ptr[1]=43; ptr[2]=44; test_ref_cast(ptr_vref<3>(ptr),ptr); int v[3] = {1,1,1}; ptr_vref<3>(ptr) += vref(v); BOOST_TEST(ptr[0]==43); BOOST_TEST(ptr[1]==44); BOOST_TEST(ptr[2]==45); } return boost::report_errors(); }