📄 time_get_members_wchar_t.cc
字号:
// 2001-10-02 Benjamin Kosnik <bkoz@redhat.com>// Copyright (C) 2001, 2002 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.5.1.1 time_get members#include <locale>#include <sstream>#include <testsuite_hooks.h>// XXX This test is not working for non-glibc locale models.// { dg-do run { xfail *-*-* } }#ifdef _GLIBCPP_USE_WCHAR_Tvoid test01(){ using namespace std; typedef time_base::dateorder dateorder; typedef istreambuf_iterator<wchar_t> iterator_type; bool test = true; // basic construction and sanity checks. locale loc_c = locale::classic(); locale loc_hk("en_HK"); locale loc_fr("fr_FR@euro"); locale loc_de("de_DE"); VERIFY( loc_hk != loc_c ); VERIFY( loc_hk != loc_fr ); VERIFY( loc_hk != loc_de ); VERIFY( loc_de != loc_fr ); // cache the __timepunct facets, for quicker gdb inspection const __timepunct<wchar_t>& time_c = use_facet<__timepunct<wchar_t> >(loc_c); const __timepunct<wchar_t>& time_de = use_facet<__timepunct<wchar_t> >(loc_de); const __timepunct<wchar_t>& time_hk = use_facet<__timepunct<wchar_t> >(loc_hk); const __timepunct<wchar_t>& time_fr = use_facet<__timepunct<wchar_t> >(loc_fr); const wstring empty; // create an ostream-derived object, cache the time_get facet iterator_type end; wistringstream iss; const time_get<wchar_t>& tim_get = use_facet<time_get<wchar_t> >(iss.getloc()); const ios_base::iostate good = ios_base::goodbit; ios_base::iostate errorstate = good; // create "C" time objects const tm time_bday = { 0, 0, 12, 4, 3, 71 }; const wchar_t* all = L"%a %A %b %B %c %d %H %I %j %m %M %p %s %U " L"%w %W %x %X %y %Y %Z %%"; const wchar_t* date = L"%A, the second of %B"; const wchar_t* date_ex = L"%Ex"; // 1 // dateorder date_order() const iss.imbue(loc_c); dateorder do1 = tim_get.date_order(); // VERIFY( do1 == time_base::mdy ); VERIFY( do1 == time_base::no_order ); // 2 // iter_type // get_time(iter_type, iter_type, ios_base&, ios_base::iostate&, tm*) const // sanity checks for "C" locale iss.str(L"12:00:00"); iterator_type is_it01(iss); tm time01; errorstate = good; tim_get.get_time(is_it01, end, iss, errorstate, &time01); VERIFY( time01.tm_sec == time_bday.tm_sec ); VERIFY( time01.tm_min == time_bday.tm_min ); VERIFY( time01.tm_hour == time_bday.tm_hour ); VERIFY( errorstate == ios_base::eofbit ); iss.str(L"12:00:00 "); iterator_type is_it02(iss); tm time02; errorstate = good; tim_get.get_time(is_it02, end, iss, errorstate, &time02); VERIFY( time01.tm_sec == time_bday.tm_sec ); VERIFY( time01.tm_min == time_bday.tm_min ); VERIFY( time01.tm_hour == time_bday.tm_hour ); VERIFY( errorstate == good ); iss.str(L"12:61:00 "); iterator_type is_it03(iss); tm time03; errorstate = good; tim_get.get_time(is_it03, end, iss, errorstate, &time03); VERIFY( time01.tm_hour == time_bday.tm_hour ); VERIFY( errorstate == ios_base::failbit ); iss.str(L"12:a:00 "); iterator_type is_it04(iss); tm time04; errorstate = good; tim_get.get_time(is_it04, end, iss, errorstate, &time04); VERIFY( time01.tm_hour == time_bday.tm_hour ); VERIFY( *is_it04 == 'a'); VERIFY( errorstate == ios_base::failbit ); // inspection of named locales, de_DE iss.imbue(loc_de); iss.str(L"12:00:00"); iterator_type is_it10(iss); tm time10; errorstate = good; tim_get.get_time(is_it10, end, iss, errorstate, &time10); VERIFY( time10.tm_sec == time_bday.tm_sec ); VERIFY( time10.tm_min == time_bday.tm_min ); VERIFY( time10.tm_hour == time_bday.tm_hour ); VERIFY( errorstate == ios_base::eofbit ); // inspection of named locales, en_HK iss.imbue(loc_hk); iss.str(L"12:00:00 PST"); // Hong Kong in California! Well, they have Paris in Vegas... this // is all a little disney-esque anyway. Besides, you can get decent // Dim Sum in San Francisco. iterator_type is_it20(iss); tm time20; errorstate = good; tim_get.get_time(is_it20, end, iss, errorstate, &time20); VERIFY( time10.tm_sec == time_bday.tm_sec ); VERIFY( time10.tm_min == time_bday.tm_min ); VERIFY( time10.tm_hour == time_bday.tm_hour ); VERIFY( errorstate == ios_base::eofbit );}void test02(){ using namespace std; typedef time_base::dateorder dateorder; typedef istreambuf_iterator<wchar_t> iterator_type; bool test = true; // basic construction and sanity checks. locale loc_c = locale::classic(); locale loc_hk("en_HK"); locale loc_fr("fr_FR@euro"); locale loc_de("de_DE"); VERIFY( loc_hk != loc_c ); VERIFY( loc_hk != loc_fr ); VERIFY( loc_hk != loc_de ); VERIFY( loc_de != loc_fr ); // cache the __timepunct facets, for quicker gdb inspection const __timepunct<wchar_t>& time_c = use_facet<__timepunct<wchar_t> >(loc_c); const __timepunct<wchar_t>& time_de = use_facet<__timepunct<wchar_t> >(loc_de); const __timepunct<wchar_t>& time_hk = use_facet<__timepunct<wchar_t> >(loc_hk); const __timepunct<wchar_t>& time_fr = use_facet<__timepunct<wchar_t> >(loc_fr); const wstring empty; // create an ostream-derived object, cache the time_get facet iterator_type end; wistringstream iss; const time_get<wchar_t>& tim_get = use_facet<time_get<wchar_t> >(iss.getloc()); const ios_base::iostate good = ios_base::goodbit; ios_base::iostate errorstate = good; // create "C" time objects const tm time_bday = { 0, 0, 12, 4, 3, 71 }; const wchar_t* all = L"%a %A %b %B %c %d %H %I %j %m %M %p %s %U " L"%w %W %x %X %y %Y %Z %%"; const wchar_t* date = L"%A, the second of %B"; const wchar_t* date_ex = L"%Ex"; // iter_type // get_weekday(iter_type, iter_type, ios_base&, // ios_base::iostate&, tm*) const // sanity checks for "C" locale iss.imbue(loc_c); iss.str(L"Sunday"); iterator_type is_it01(iss); tm time01; errorstate = good; tim_get.get_weekday(is_it01, end, iss, errorstate, &time01); VERIFY( time01.tm_wday == time_bday.tm_wday ); VERIFY( errorstate == ios_base::eofbit ); iss.str(L"Sun"); iterator_type is_it02(iss); tm time02; errorstate = good; tim_get.get_weekday(is_it02, end, iss, errorstate, &time02); VERIFY( time02.tm_wday == time_bday.tm_wday ); VERIFY( errorstate == ios_base::eofbit ); iss.str(L"Sun "); iterator_type is_it03(iss); tm time03; errorstate = good; tim_get.get_weekday(is_it03, end, iss, errorstate, &time03); VERIFY( time03.tm_wday == time_bday.tm_wday ); VERIFY( errorstate == good ); VERIFY( *is_it03 == ' '); iss.str(L"San"); iterator_type is_it04(iss); tm time04; time04.tm_wday = 4; errorstate = good; tim_get.get_weekday(is_it04, end, iss, errorstate, &time04); VERIFY( time04.tm_wday == 4 ); VERIFY( *is_it04 == 'n'); VERIFY( errorstate == ios_base::failbit ); iss.str(L"Tuesday "); iterator_type is_it05(iss); tm time05; errorstate = good; tim_get.get_weekday(is_it05, end, iss, errorstate, &time05); VERIFY( time05.tm_wday == 2 ); VERIFY( errorstate == good ); VERIFY( *is_it05 == ' '); iss.str(L"Tuesducky "); // Kind of like Fryday, without the swirls. iterator_type is_it06(iss); tm time06; time06.tm_wday = 4; errorstate = good; tim_get.get_weekday(is_it06, end, iss, errorstate, &time06); VERIFY( time06.tm_wday == 4 ); VERIFY( errorstate == ios_base::failbit ); VERIFY( *is_it05 == 'u'); // inspection of named locales, de_DE iss.imbue(loc_de); iss.str(L"Sonntag"); iterator_type is_it10(iss); tm time10; errorstate = good; tim_get.get_weekday(is_it10, end, iss, errorstate, &time10); VERIFY( time10.tm_wday == time_bday.tm_wday ); VERIFY( errorstate == ios_base::eofbit ); // inspection of named locales, en_HK iss.imbue(loc_hk); iss.str(L"Sunday"); iterator_type is_it20(iss); tm time20; errorstate = good; tim_get.get_weekday(is_it20, end, iss, errorstate, &time20); VERIFY( time20.tm_wday == time_bday.tm_wday ); VERIFY( errorstate == ios_base::eofbit );}void test03(){ using namespace std; typedef time_base::dateorder dateorder; typedef istreambuf_iterator<wchar_t> iterator_type; bool test = true; // basic construction and sanity checks. locale loc_c = locale::classic(); locale loc_hk("en_HK"); locale loc_fr("fr_FR@euro"); locale loc_de("de_DE"); VERIFY( loc_hk != loc_c ); VERIFY( loc_hk != loc_fr ); VERIFY( loc_hk != loc_de ); VERIFY( loc_de != loc_fr ); // cache the __timepunct facets, for quicker gdb inspection const __timepunct<wchar_t>& time_c = use_facet<__timepunct<wchar_t> >(loc_c); const __timepunct<wchar_t>& time_de = use_facet<__timepunct<wchar_t> >(loc_de); const __timepunct<wchar_t>& time_hk = use_facet<__timepunct<wchar_t> >(loc_hk); const __timepunct<wchar_t>& time_fr = use_facet<__timepunct<wchar_t> >(loc_fr); const wstring empty; // create an ostream-derived object, cache the time_get facet iterator_type end; wistringstream iss; const time_get<wchar_t>& tim_get = use_facet<time_get<wchar_t> >(iss.getloc()); const ios_base::iostate good = ios_base::goodbit; ios_base::iostate errorstate = good; // create "C" time objects const tm time_bday = { 0, 0, 12, 4, 3, 71 }; const wchar_t* all = L"%a %A %b %B %c %d %H %I %j %m %M %p %s %U " L"%w %W %x %X %y %Y %Z %%"; const wchar_t* date = L"%A, the second of %B"; const wchar_t* date_ex = L"%Ex"; // iter_type // get_monthname(iter_type, iter_type, ios_base&, // ios_base::iostate&, tm*) const // sanity checks for "C" locale iss.imbue(loc_c); iss.str(L"April"); iterator_type is_it01(iss); tm time01; errorstate = good; tim_get.get_monthname(is_it01, end, iss, errorstate, &time01); VERIFY( time01.tm_wday == time_bday.tm_wday ); VERIFY( errorstate == ios_base::eofbit ); iss.str(L"Apr"); iterator_type is_it02(iss); tm time02; errorstate = good; tim_get.get_monthname(is_it02, end, iss, errorstate, &time02); VERIFY( time02.tm_mon == time_bday.tm_mon ); VERIFY( errorstate == ios_base::eofbit ); iss.str(L"Apr "); iterator_type is_it03(iss); tm time03; errorstate = good; tim_get.get_monthname(is_it03, end, iss, errorstate, &time03); VERIFY( time03.tm_mon == time_bday.tm_mon ); VERIFY( errorstate == good ); VERIFY( *is_it03 == ' '); iss.str(L"Aar"); iterator_type is_it04(iss); tm time04; time04.tm_mon = 5; errorstate = good; tim_get.get_monthname(is_it04, end, iss, errorstate, &time04); VERIFY( time04.tm_mon == 5 ); VERIFY( *is_it04 == 'a'); VERIFY( errorstate == ios_base::failbit ); iss.str(L"December "); iterator_type is_it05(iss); tm time05; errorstate = good; tim_get.get_monthname(is_it05, end, iss, errorstate, &time05); VERIFY( time05.tm_mon == 11 ); VERIFY( errorstate == good ); VERIFY( *is_it05 == ' '); iss.str(L"Decelember "); iterator_type is_it06(iss); tm time06; time06.tm_mon = 4; errorstate = good; tim_get.get_monthname(is_it06, end, iss, errorstate, &time06); VERIFY( time06.tm_mon == 4 );
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -