wchar_t_out.pass.cpp revision bc8d3f97eb5c958007f2713238472e0c1c8fe02c
1//===----------------------------------------------------------------------===// 2// 3// ��������������������The LLVM Compiler Infrastructure 4// 5// This file is distributed under the University of Illinois Open Source 6// License. See LICENSE.TXT for details. 7// 8//===----------------------------------------------------------------------===// 9 10// <locale> 11 12// template <> class codecvt<wchar_t, char, mbstate_t> 13 14// result out(stateT& state, 15// const internT* from, const internT* from_end, const internT*& from_next, 16// externT* to, externT* to_end, externT*& to_next) const; 17 18#include <locale> 19#include <string> 20#include <vector> 21#include <cassert> 22 23typedef std::codecvt<wchar_t, char, std::mbstate_t> F; 24 25int main() 26{ 27 std::locale l = std::locale::classic(); 28 const F& f = std::use_facet<F>(l); 29 { 30 const std::basic_string<F::intern_type> from(L"some text"); 31 std::vector<char> to(from.size()+1); 32 std::mbstate_t mbs; 33 const F::intern_type* from_next = 0; 34 char* to_next = 0; 35 F::result r = f.out(mbs, from.data(), from.data() + from.size(), from_next, 36 to.data(), to.data() + to.size(), to_next); 37 assert(r == F::ok); 38 assert(from_next - from.data() == from.size()); 39 assert(to_next - to.data() == from.size()); 40 assert(to.data() == std::string("some text")); 41 } 42 { 43 std::basic_string<F::intern_type> from(L"some text"); 44 from[4] = '\0'; 45 std::vector<char> to(from.size()+1); 46 std::mbstate_t mbs; 47 const F::intern_type* from_next = 0; 48 char* to_next = 0; 49 F::result r = f.out(mbs, from.data(), from.data() + from.size(), from_next, 50 to.data(), to.data() + to.size(), to_next); 51 assert(r == F::ok); 52 assert(from_next - from.data() == from.size()); 53 assert(to_next - to.data() == from.size()); 54 assert(to.data() == std::string("some\0text", from.size())); 55 } 56 { 57 std::basic_string<F::intern_type> from(L"some text"); 58 std::vector<char> to(from.size()-1); 59 std::mbstate_t mbs; 60 const F::intern_type* from_next = 0; 61 char* to_next = 0; 62 F::result r = f.out(mbs, from.data(), from.data() + from.size(), from_next, 63 to.data(), to.data() + to.size()-1, to_next); 64 assert(r == F::partial); 65 assert(from_next - from.data() == to.size()-1); 66 assert(to_next - to.data() == to.size()-1); 67 assert(to.data() == std::string("some te")); 68 } 69} 70