// Copyright 2008-2024 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) #if __cplusplus <= 199711L #include int main() { std::cout << "Test not applicable due to lack of C++11 support in the compiler" << std::endl; return 0; } #else #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 { }; int main() { using namespace boost::qvm; BOOST_QVM_STATIC_ASSERT((is_quat>::value)); BOOST_QVM_STATIC_ASSERT((is_quat>::value)); BOOST_QVM_STATIC_ASSERT((is_quat const>::value)); BOOST_QVM_STATIC_ASSERT((is_quat const>::value)); BOOST_QVM_STATIC_ASSERT((!is_quat,4>>::value)); BOOST_QVM_STATIC_ASSERT((!is_quat,4>,4>>::value)); same_type>::scalar_type,int>(); same_type< quat, deduce_quat>::type >(); std::array arr1 = {0,1,2,3}; std::array arr2 = {0,1,2,3}; std::array const arr3 = {0,1,2,3}; std::array const arr4 = {0,1,2,3}; BOOST_TEST((quat_traits>::read_element<0>(arr1)==0)); BOOST_TEST((quat_traits>::read_element<1>(arr1)==1)); BOOST_TEST((quat_traits>::read_element<2>(arr1)==2)); BOOST_TEST((quat_traits>::read_element<3>(arr1)==3)); BOOST_TEST((quat_traits>::read_element<0>(arr2)==0)); BOOST_TEST((quat_traits>::read_element<1>(arr2)==1)); BOOST_TEST((quat_traits>::read_element<2>(arr2)==2)); BOOST_TEST((quat_traits>::read_element<3>(arr2)==3)); BOOST_TEST((quat_traits const>::read_element<0>(arr3)==0)); BOOST_TEST((quat_traits const>::read_element<1>(arr3)==1)); BOOST_TEST((quat_traits const>::read_element<2>(arr3)==2)); BOOST_TEST((quat_traits const>::read_element<3>(arr3)==3)); BOOST_TEST((quat_traits const>::read_element<0>(arr4)==0)); BOOST_TEST((quat_traits const>::read_element<1>(arr4)==1)); BOOST_TEST((quat_traits const>::read_element<2>(arr4)==2)); BOOST_TEST((quat_traits const>::read_element<3>(arr4)==3)); BOOST_TEST((quat_traits>::read_element_idx(0,arr1)==0)); BOOST_TEST((quat_traits>::read_element_idx(1,arr1)==1)); BOOST_TEST((quat_traits>::read_element_idx(2,arr1)==2)); BOOST_TEST((quat_traits>::read_element_idx(3,arr1)==3)); BOOST_TEST((quat_traits>::read_element_idx(0,arr2)==0)); BOOST_TEST((quat_traits>::read_element_idx(1,arr2)==1)); BOOST_TEST((quat_traits>::read_element_idx(2,arr2)==2)); BOOST_TEST((quat_traits>::read_element_idx(3,arr2)==3)); BOOST_TEST((quat_traits const>::read_element_idx(0,arr3)==0)); BOOST_TEST((quat_traits const>::read_element_idx(1,arr3)==1)); BOOST_TEST((quat_traits const>::read_element_idx(2,arr3)==2)); BOOST_TEST((quat_traits const>::read_element_idx(3,arr3)==3)); BOOST_TEST((quat_traits const>::read_element_idx(0,arr4)==0)); BOOST_TEST((quat_traits const>::read_element_idx(1,arr4)==1)); BOOST_TEST((quat_traits const>::read_element_idx(2,arr4)==2)); BOOST_TEST((quat_traits const>::read_element_idx(3,arr4)==3)); BOOST_TEST((&quat_traits>::write_element<0>(arr1)==&arr1[0])); BOOST_TEST((&quat_traits>::write_element<1>(arr1)==&arr1[1])); BOOST_TEST((&quat_traits>::write_element<2>(arr1)==&arr1[2])); BOOST_TEST((&quat_traits>::write_element<3>(arr1)==&arr1[3])); BOOST_TEST((&quat_traits>::write_element_idx(0,arr1)==&arr1[0])); BOOST_TEST((&quat_traits>::write_element_idx(1,arr1)==&arr1[1])); BOOST_TEST((&quat_traits>::write_element_idx(2,arr1)==&arr1[2])); BOOST_TEST((&quat_traits>::write_element_idx(3,arr1)==&arr1[3])); return boost::report_errors(); } #endif