/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // test_array.cpp // (C) Copyright 2002 Robert Ramey - http://www.rrsd.com . // Use, modification and distribution is 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) // should pass compilation and execution #include #include #include // remove #include #if defined(BOOST_NO_STDC_NAMESPACE) namespace std{ using ::remove; } #endif #include "test_tools.hpp" #include #include #include #include "A.hpp" #include "A.ipp" struct array_equal_to //: public std::binary_function { template bool operator()(const T & _Left, const U & _Right) const { // consider alignment int count_left = sizeof(_Left) / ( static_cast(static_cast(&_Left[1])) - static_cast(static_cast(&_Left[0])) ); int count_right = sizeof(_Right) / ( static_cast(static_cast(&_Right[1])) - static_cast(static_cast(&_Right[0])) ); if(count_right != count_left) return false; while(count_left-- > 0){ if(_Left[count_left] == _Right[count_left]) continue; return false; } return true; } }; template int test_array(T) { const char * testfile = boost::archive::tmpnam(NULL); BOOST_REQUIRE(NULL != testfile); // test array of objects const T a_array[10]={T(),T(),T(),T(),T(),T(),T(),T(),T(),T()}; const T b_array[2][3]={{T(),T(),T()},{T(),T(),T()}}; const boost::array c_array = boost::array(); { test_ostream os(testfile, TEST_STREAM_FLAGS); test_oarchive oa(os, TEST_ARCHIVE_FLAGS); oa << boost::serialization::make_nvp("a_array", a_array); oa << boost::serialization::make_nvp("b_array", b_array); oa << boost::serialization::make_nvp("c_array", c_array); } { T a_array1[10]; T b_array1[2][3]; boost::array c_array1; test_istream is(testfile, TEST_STREAM_FLAGS); test_iarchive ia(is, TEST_ARCHIVE_FLAGS); ia >> boost::serialization::make_nvp("a_array", a_array1); ia >> boost::serialization::make_nvp("b_array", b_array1); ia >> boost::serialization::make_nvp("c_array", c_array1); array_equal_to/**/ Compare; BOOST_CHECK(Compare(a_array, a_array1)); BOOST_CHECK(Compare(b_array[0], b_array1[0])); BOOST_CHECK(Compare(b_array[1], b_array1[1])); BOOST_CHECK(Compare(c_array, c_array1)); } { T a_array1[9]; test_istream is(testfile, TEST_STREAM_FLAGS); BOOST_TRY { test_iarchive ia(is, TEST_ARCHIVE_FLAGS); bool exception_invoked = false; BOOST_TRY { ia >> boost::serialization::make_nvp("a_array", a_array1); } BOOST_CATCH (boost::archive::archive_exception ae){ BOOST_CHECK( boost::archive::archive_exception::array_size_too_short == ae.code ); exception_invoked = true; } BOOST_CATCH_END BOOST_CHECK(exception_invoked); } BOOST_CATCH (boost::archive::archive_exception ae){} BOOST_CATCH_END } std::remove(testfile); return EXIT_SUCCESS; } int test_main( int /* argc */, char* /* argv */[] ) { int res = test_array(A()); // test an int array for which optimized versions should be available if (res == EXIT_SUCCESS) res = test_array(0); return res; } // EOF