⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 time_get_members_wchar_t.cc

📁 俄罗斯高人Mamaich的Pocket gcc编译器(运行在PocketPC上)的全部源代码。
💻 CC
📖 第 1 页 / 共 2 页
字号:
// 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 + -