// (C) Copyright John Maddock 2005. // Use, modification and distribution are subject to 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 TEST_STD_HEADERS #include #else #include #endif #include #include #include #include "verify_return.hpp" template void check_tuple_access(T& a, const U&) { typedef typename T::value_type value_type; const T& ca = a; BOOST_STATIC_ASSERT((::boost::is_same< typename std::tr1::tuple_element<0,T>::type, value_type>::value)); verify_return_type(&std::tr1::get<0>(a), static_cast(0)); verify_return_type(&std::tr1::get<0>(ca), static_cast(0)); } template void check_tuple_access(T& a, const boost::mpl::true_&) { // nothing to check the array is empty } template void check_array(T& a) { typedef typename T::reference reference; typedef typename T::const_reference const_reference; typedef typename T::iterator iterator; typedef typename T::const_iterator const_iterator; typedef typename T::size_type size_type; typedef typename T::difference_type difference_type; typedef typename T::value_type value_type; typedef typename T::reverse_iterator reverse_iterator; typedef typename T::const_reverse_iterator const_reverse_iterator; BOOST_STATIC_ASSERT((::boost::is_same::value)); BOOST_STATIC_ASSERT((::boost::is_same::value)); BOOST_STATIC_ASSERT((::boost::is_same::value)); BOOST_STATIC_ASSERT((::boost::is_same::value)); BOOST_STATIC_ASSERT((::boost::is_same, reverse_iterator>::value)); BOOST_STATIC_ASSERT((::boost::is_same, const_reverse_iterator>::value)); const T& ca = a; const T& ca2 = a; verify_return_type(a.begin(), iterator()); verify_return_type(ca.begin(), const_iterator()); verify_return_type(a.end(), iterator()); verify_return_type(ca.end(), const_iterator()); verify_return_type(a.rbegin(), reverse_iterator()); verify_return_type(ca.rbegin(), const_reverse_iterator()); verify_return_type(a.rend(), reverse_iterator()); verify_return_type(ca.rend(), const_reverse_iterator()); verify_return_type(ca.size(), size_type(0)); verify_return_type(ca.max_size(), size_type(0)); verify_return_type(ca.empty(), false); verify_return_type(&a[0], static_cast(0)); verify_return_type(&ca[0], static_cast(0)); verify_return_type(&a.at(0), static_cast(0)); verify_return_type(&ca.at(0), static_cast(0)); verify_return_type(&a.front(), static_cast(0)); verify_return_type(&ca.front(), static_cast(0)); verify_return_type(&a.back(), static_cast(0)); verify_return_type(&ca.back(), static_cast(0)); verify_return_type(a.data(), static_cast(0)); verify_return_type(ca.data(), static_cast(0)); // swap: std::tr1::swap(a, a); verify_return_type(ca == ca2, false); verify_return_type(ca != ca2, false); verify_return_type(ca < ca2, false); verify_return_type(ca > ca2, false); verify_return_type(ca <= ca2, false); verify_return_type(ca >= ca2, false); typedef boost::mpl::bool_::value == 0> emtyness; check_tuple_access(a, emtyness()); } int main() { std::tr1::array a1 = {}; check_array(a1); BOOST_STATIC_ASSERT((std::tr1::tuple_size >::value == 2)); std::tr1::array a2 = { "abc", "def", "", "y", }; check_array(a2); BOOST_STATIC_ASSERT((std::tr1::tuple_size >::value == 4)); std::tr1::array a3 = {}; check_array(a3); BOOST_STATIC_ASSERT((std::tr1::tuple_size >::value == 0)); return 0; }