Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(611)

Unified Diff: gcc/libstdc++-v3/testsuite/ext/codecvt/char-1.cc

Issue 3050029: [gcc] GCC 4.5.0=>4.5.1 (Closed) Base URL: ssh://git@gitrw.chromium.org:9222/nacl-toolchain.git
Patch Set: Created 10 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « gcc/libstdc++-v3/testsuite/ext/codecvt/1.cc ('k') | gcc/libstdc++-v3/testsuite/ext/concept_checks.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gcc/libstdc++-v3/testsuite/ext/codecvt/char-1.cc
diff --git a/gcc/libstdc++-v3/testsuite/ext/codecvt/char-1.cc b/gcc/libstdc++-v3/testsuite/ext/codecvt/char-1.cc
deleted file mode 100644
index 733dff8a07861dbbf178f2d97948148f7452014f..0000000000000000000000000000000000000000
--- a/gcc/libstdc++-v3/testsuite/ext/codecvt/char-1.cc
+++ /dev/null
@@ -1,141 +0,0 @@
-// { dg-require-iconv "UCS-2BE" }
-// { dg-require-iconv "ISO-8859-15" }
-
-// 2000-08-22 Benjamin Kosnik <bkoz@cygnus.com>
-
-// Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2009
-// 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 3, 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 COPYING3. If not see
-// <http://www.gnu.org/licenses/>.
-
-// 22.2.1.5 - Template class codecvt [lib.locale.codecvt]
-#include <locale>
-#include <cstring>
-#include <testsuite_hooks.h>
-#include <ext/codecvt_specializations.h>
-
-/*
-> how do I check that these conversions are correct?
-Very easy. Since all the characters are from ASCII you simply
-zero-extend the values.
-
-drepper$ echo 'black pearl jasmine tea' | od -t x1
-0000000 62 6c 61 63 6b 20 70 65 61 72 6c 20 6a 61 73 6d
-0000020 69 6e 65 20 74 65 61 0a
-
-So the UCS-2 string is
-
-0x0062, 0x006c, 0x0061, ...
-
-You get the idea. With iconv() you have to take care of the
-byte-order, though. UCS-2 can mean little- or big endian. Looking at
-your result
-
-> $9 = 25856
-
-it shows that the other byte-order is used (25856 == 0x6500).
-*/
-
-// Partial specialization using encoding_state.
-// codecvt<unicode_t, char, encoding_state>
-// UNICODE - UCS2 (big endian)
-void test01()
-{
- using namespace std;
- typedef codecvt_base::result result;
- typedef unsigned short int_type;
- typedef char ext_type;
- typedef __gnu_cxx::encoding_state state_type;
- typedef codecvt<int_type, ext_type, state_type> unicode_codecvt;
- typedef char_traits<int_type> int_traits;
- typedef char_traits<ext_type> ext_traits;
-
- bool test __attribute__((unused)) = true;
- const ext_type* e_lit = "black pearl jasmine tea";
- int size = strlen(e_lit);
-
- char i_lit_base[50] __attribute__((aligned(__alignof__(int_type)))) =
- {
- 0x00, 0x62, 0x00, 0x6c, 0x00, 0x61, 0x00, 0x63, 0x00, 0x6b, 0x00, 0x20,
- 0x00, 0x70, 0x00, 0x65, 0x00, 0x61, 0x00, 0x72, 0x00, 0x6c, 0x00, 0x20,
- 0x00, 0x6a, 0x00, 0x61, 0x00, 0x73, 0x00, 0x6d, 0x00, 0x69, 0x00, 0x6e,
- 0x00, 0x65, 0x00, 0x20, 0x00, 0x74, 0x00, 0x65, 0x00, 0x61, 0x00, 0xa0
- };
- const int_type* i_lit = reinterpret_cast<int_type*>(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<unicode_codecvt>(loc) );
- const unicode_codecvt& cvt = use_facet<unicode_codecvt>(loc);
-
- // in
- // unicode_codecvt::state_type state01("UCS-2BE", "ISO-8859-15", 0xfeff, 0);
- unicode_codecvt::state_type state01("UCS-2BE", "ISO-8859-15", 0, 0);
-
- // internal encoding is bigger because of bom
- 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", "ISO-8859-15", 0, 0);
- result r2 = cvt.out(state02, i_lit, i_lit + size, ifrom_next,
- e_arr, e_arr + size, eto_next);
- 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", "ISO-8859-15", 0, 0);
- 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 == 2 ); // Target-dependent.
-
- VERIFY( !cvt.always_noconv() );
-
- unicode_codecvt::state_type state04("UCS-2BE", "ISO-8859-15", 0, 0);
- 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;
-}
-
-int main ()
-{
- test01();
- return 0;
-}
« no previous file with comments | « gcc/libstdc++-v3/testsuite/ext/codecvt/1.cc ('k') | gcc/libstdc++-v3/testsuite/ext/concept_checks.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698