toupper_many.pass.cpp revision b64f8b07c104c6cc986570ac8ee0ed16a9f23976
19b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar//===----------------------------------------------------------------------===// 29b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar// 39b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar// The LLVM Compiler Infrastructure 49b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar// 59b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar// This file is dual licensed under the MIT and the University of Illinois Open 69b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar// Source Licenses. See LICENSE.TXT for details. 79b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar// 89b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar//===----------------------------------------------------------------------===// 99b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar 1098cabbad47a4d9db6b7e95c950d3302c110d1b02Argyrios Kyrtzidis// <locale> 119b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar 1298cabbad47a4d9db6b7e95c950d3302c110d1b02Argyrios Kyrtzidis// template <class charT> class ctype_byname; 139b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar 149ef6537a894c33003359b1f9b9676e9178e028b7Ted Kremenek// const charT* toupper(charT* low, const charT* high) const; 159b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar 169b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar#include <locale> 179b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar#include <string> 189b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar#include <cassert> 199b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar 209b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbarint main() 219b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar{ 229b414d3e2d0cb84512b55a3275a98490b090162aDaniel Dunbar { 23 std::locale l("en_US"); 24 { 25 typedef std::ctype<char> F; 26 const F& f = std::use_facet<F>(l); 27 std::string in("\xFA A\x07.a1"); 28 29 assert(f.toupper(&in[0], in.data() + in.size()) == in.data() + in.size()); 30 assert(in[0] == '\xFA'); 31 assert(in[1] == ' '); 32 assert(in[2] == 'A'); 33 assert(in[3] == '\x07'); 34 assert(in[4] == '.'); 35 assert(in[5] == 'A'); 36 assert(in[6] == '1'); 37 } 38 } 39 { 40 std::locale l("C"); 41 { 42 typedef std::ctype<char> F; 43 const F& f = std::use_facet<F>(l); 44 std::string in("\xFA A\x07.a1"); 45 46 assert(f.toupper(&in[0], in.data() + in.size()) == in.data() + in.size()); 47 assert(in[0] == '\xFA'); 48 assert(in[1] == ' '); 49 assert(in[2] == 'A'); 50 assert(in[3] == '\x07'); 51 assert(in[4] == '.'); 52 assert(in[5] == 'A'); 53 assert(in[6] == '1'); 54 } 55 } 56 { 57 std::locale l("en_US"); 58 { 59 typedef std::ctype<wchar_t> F; 60 const F& f = std::use_facet<F>(l); 61 std::wstring in(L"\xFA A\x07.a1"); 62 63 assert(f.toupper(&in[0], in.data() + in.size()) == in.data() + in.size()); 64 assert(in[0] == L'\xDA'); 65 assert(in[1] == L' '); 66 assert(in[2] == L'A'); 67 assert(in[3] == L'\x07'); 68 assert(in[4] == L'.'); 69 assert(in[5] == L'A'); 70 assert(in[6] == L'1'); 71 } 72 } 73 { 74 std::locale l("C"); 75 { 76 typedef std::ctype<wchar_t> F; 77 const F& f = std::use_facet<F>(l); 78 std::wstring in(L"\xFA A\x07.a1"); 79 80 assert(f.toupper(&in[0], in.data() + in.size()) == in.data() + in.size()); 81 assert(in[0] == L'\xFA'); 82 assert(in[1] == L' '); 83 assert(in[2] == L'A'); 84 assert(in[3] == L'\x07'); 85 assert(in[4] == L'.'); 86 assert(in[5] == L'A'); 87 assert(in[6] == L'1'); 88 } 89 } 90} 91