/////////1/////////2/////////3/////////4/////////5/////////6/////////7/////////8 // test_iterators.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) #include #include // for rand #include #include // used to test stream iterators #include #include // begin #include // setlocale #include #ifdef BOOST_NO_STDC_NAMESPACE namespace std{ using ::rand; } #endif #include #if BOOST_WORKAROUND(BOOST_DINKUMWARE_STDLIB, == 1) #include #endif #ifndef BOOST_NO_CWCHAR #include #include #endif #include #include #include #include #include #include "test_tools.hpp" #ifndef BOOST_NO_CWCHAR void test_wchar_from_mb(const wchar_t *la, const char * a, const unsigned int size){ typedef boost::archive::iterators::wchar_from_mb translator; BOOST_CHECK(( std::equal( translator(a), translator(a + size), la ) )); } void test_mb_from_wchar(const char * a, const wchar_t *la, const unsigned int size){ typedef boost::archive::iterators::mb_from_wchar translator; BOOST_CHECK( std::equal( translator(la), translator(la + size), a ) ); } void test_roundtrip(const wchar_t * la){ std::size_t s = std::wcslen(la); std::vector a; { typedef boost::archive::iterators::mb_from_wchar translator; std::copy( translator(la), translator(la + s), std::back_inserter(a) ); // note: wchar_from_mb NEEDS a termination null in order to function! a.push_back(static_cast(0)); } BOOST_CHECK(a.size() > 0); std::vector la2; { typedef boost::archive::iterators::wchar_from_mb::const_iterator> translator; std::copy( translator(a.begin()), translator(), std::back_inserter(la2) ); } BOOST_CHECK(la2.size() == s); BOOST_CHECK(std::equal(la, la + s, la2.begin())); } #endif template void test_xml_escape( const CharType * xml_escaped, const CharType * xml, unsigned int size ){ typedef boost::archive::iterators::xml_escape translator; BOOST_CHECK( std::equal( translator(xml), translator(xml + size), xml_escaped ) ); } template void test_xml_unescape( const CharType * xml, const CharType * xml_escaped, unsigned int size ){ // test xml_unescape typedef boost::archive::iterators::xml_unescape translator; BOOST_CHECK( std::equal( translator(xml_escaped), translator(xml_escaped + size), xml ) ); } template void test_transform_width(unsigned int size){ // test transform_width char rawdata[8]; char * rptr; for(rptr = rawdata + size; rptr-- > rawdata;) *rptr = static_cast(0xff & std::rand()); // convert 8 to 6 bit characters typedef boost::archive::iterators::transform_width< char *, BitsOut, BitsIn > translator1; std::vector vout; std::copy( translator1(static_cast(rawdata)), translator1(rawdata + size), std::back_inserter(vout) ); // check to see we got the expected # of characters out if(0 == size) BOOST_CHECK(vout.size() == 0); else BOOST_CHECK(vout.size() == (size * BitsIn - 1 ) / BitsOut + 1); typedef boost::archive::iterators::transform_width< std::vector::iterator, BitsIn, BitsOut > translator2; std::vector vin; std::copy( translator2(vout.begin()), translator2(vout.end()), std::back_inserter(vin) ); // check to see we got the expected # of characters out BOOST_CHECK(vin.size() == size); BOOST_CHECK( std::equal( rawdata, rawdata + size, vin.begin() ) ); } template void test_stream_iterators( const CharType * test_data, unsigned int size ){ std::basic_stringstream ss; boost::archive::iterators::ostream_iterator osi = boost::archive::iterators::ostream_iterator(ss); std::copy(test_data, test_data + size, osi); BOOST_CHECK(size == ss.str().size()); boost::archive::iterators::istream_iterator isi = boost::archive::iterators::istream_iterator(ss); BOOST_CHECK(std::equal(test_data, test_data + size,isi)); } int test_main(int /* argc */, char* /* argv */ [] ) { const char xml[] = "<+>+&+\"+'"; const char xml_escaped[] = "<+>+&+"+'"; test_xml_escape( xml_escaped, xml, sizeof(xml) / sizeof(char) - 1 ); test_xml_unescape( xml, xml_escaped, sizeof(xml_escaped) / sizeof(char) - 1 ); #ifndef BOOST_NO_CWCHAR const wchar_t wxml[] = L"<+>+&+\"+'"; const wchar_t wxml_escaped[] = L"<+>+&+"+'"; test_xml_escape( wxml_escaped, wxml, sizeof(wxml) / sizeof(wchar_t) - 1 ); test_xml_unescape( wxml, wxml_escaped, sizeof(wxml_escaped) / sizeof(wchar_t) - 1 ); const char b[] = "abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz"; const wchar_t lb[] = L"abcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyz"; test_mb_from_wchar(b, lb, sizeof(lb) / sizeof(wchar_t) - 1); test_wchar_from_mb(lb, b, sizeof(b) / sizeof(char) - 1); const char a[] = "abcdefghijklmnopqrstuvwxyz"; const wchar_t la[] = L"abcdefghijklmnopqrstuvwxyz"; test_mb_from_wchar(a, la, sizeof(la) / sizeof(wchar_t) - 1); test_wchar_from_mb(la, a, sizeof(a) / sizeof(char) - 1); test_roundtrip(L"z\u00df\u6c34\U0001f34c"); test_stream_iterators(la, sizeof(la)/sizeof(wchar_t) - 1); #endif test_stream_iterators(a, sizeof(a) - 1); test_transform_width<6, 8>(0); test_transform_width<6, 8>(1); test_transform_width<6, 8>(2); test_transform_width<6, 8>(3); test_transform_width<6, 8>(4); test_transform_width<6, 8>(5); test_transform_width<6, 8>(6); test_transform_width<6, 8>(7); test_transform_width<6, 8>(8); return EXIT_SUCCESS; }