// 2000-08-23 Benjamin Kosnik // Copyright (C) 2000 Free Software Foundation // // This file is part of the GNU ISO C++ Library. This library is free // software; you can redistribute it and/or modify it under the // terms of the GNU General Public License as published by the // Free Software Foundation; either version 2, or (at your option) // any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // You should have received a copy of the GNU General Public License along // with this library; see the file COPYING. If not, write to the Free // Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, // USA. // 22.2.1.5 - Template class codecvt [lib.locale.codecvt] #include #include using namespace std; #ifdef _GLIBCPP_USE_WCHAR_T void initialize_state(__enc_traits& state) { state._M_init(); } // Partial specialization using __enc_traits. // codecvt void test01() { typedef codecvt_base::result result; typedef unsigned short unicode_t; typedef unicode_t int_type; typedef wchar_t ext_type; typedef __enc_traits enc_type; typedef codecvt unicode_codecvt; typedef char_traits int_traits; typedef char_traits ext_traits; bool test = true; int size = 23; ext_type e_lit_base[24] = { 1644167168, 1811939328, 1627389952, 1660944384, 1795162112, 536870912, 1879048192, 1694498816, 1627389952, 1912602624, 1811939328, 536870912, 1778384896, 1627389952, 1929379840, 1828716544, 1761607680, 1845493760, 1694498816, 536870912, 1946157056, 1694498816, 1627389952, 167772160 }; const ext_type* e_lit = e_lit_base; int_type i_lit_base[24] = { 0x6200, 0x6c00, 0x6100, 0x6300, 0x6b00, 0x2000, 0x7000, 0x6500, 0x6100, 0x7200, 0x6c00, 0x2000, 0x6a00, 0x6100, 0x7300, 0x6d00, 0x6900, 0x6e00, 0x6500, 0x2000, 0x7400, 0x6500, 0x6100, 0xa000 }; const int_type* i_lit = i_lit_base; const ext_type* efrom_next; const int_type* ifrom_next; ext_type* e_arr = new ext_type[size + 1]; ext_type* eto_next; int_type* i_arr = new int_type[size + 1]; int_type* ito_next; // construct a locale object with the specialized facet. locale loc(locale::classic(), new unicode_codecvt); // sanity check the constructed locale has the specialized facet. VERIFY( has_facet(loc) ); const unicode_codecvt& cvt = use_facet(loc); // in unicode_codecvt::state_type state01("UCS-2BE", "UCS4", 0xfeff, 0); initialize_state(state01); result r1 = cvt.in(state01, e_lit, e_lit + size, efrom_next, i_arr, i_arr + size + 1, ito_next); VERIFY( r1 == codecvt_base::ok ); VERIFY( !int_traits::compare(i_arr, i_lit, size) ); VERIFY( efrom_next == e_lit + size ); VERIFY( ito_next == i_arr + size ); // out unicode_codecvt::state_type state02("UCS-2BE", "UCS4", 0xfeff, 0); initialize_state(state02); result r2 = cvt.out(state02, i_lit, i_lit + size, ifrom_next, e_arr, e_arr + size, eto_next); // XXX VERIFY( r2 == codecvt_base::ok ); VERIFY( !ext_traits::compare(e_arr, e_lit, size) ); VERIFY( ifrom_next == i_lit + size ); VERIFY( eto_next == e_arr + size ); // unshift ext_traits::copy(e_arr, e_lit, size); unicode_codecvt::state_type state03("UCS-2BE", "UCS4", 0xfeff, 0); initialize_state(state03); result r3 = cvt.unshift(state03, e_arr, e_arr + size, eto_next); VERIFY( r3 == codecvt_base::noconv ); VERIFY( !ext_traits::compare(e_arr, e_lit, size) ); VERIFY( eto_next == e_arr ); int i = cvt.encoding(); VERIFY( i == 0 ); VERIFY( !cvt.always_noconv() ); unicode_codecvt::state_type state04("UCS-2BE", "UCS4", 0xfeff, 0); initialize_state(state04); int j = cvt.length(state03, e_lit, e_lit + size, 5); VERIFY( j == 5 ); int k = cvt.max_length(); VERIFY( k == 1 ); delete [] e_arr; delete [] i_arr; } #endif /* !defined(_GLIBCPP_USE_WCHAR_T) */ int main () { #if _GLIBCPP_USE_WCHAR_T test01(); #endif /* !defined(_GLIBCPP_USE_WCHAR_T) */ return 0; }