// 2001-09-21 Benjamin Kosnik // 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 #include #include // XXX This test is not working for non-glibc locale models. // { dg-do run { xfail *-*-* } } void test01() { using namespace std; typedef time_base::dateorder dateorder; typedef istreambuf_iterator 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& time_c = use_facet<__timepunct >(loc_c); const __timepunct& time_de = use_facet<__timepunct >(loc_de); const __timepunct& time_hk = use_facet<__timepunct >(loc_hk); const __timepunct& time_fr = use_facet<__timepunct >(loc_fr); const string empty; // create an ostream-derived object, cache the time_get facet iterator_type end; istringstream iss; const time_get& tim_get = use_facet >(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 char* all = "%a %A %b %B %c %d %H %I %j %m %M %p %s %U " "%w %W %x %X %y %Y %Z %%"; const char* date = "%A, the second of %B"; const char* date_ex = "%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("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("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("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("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("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("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 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& time_c = use_facet<__timepunct >(loc_c); const __timepunct& time_de = use_facet<__timepunct >(loc_de); const __timepunct& time_hk = use_facet<__timepunct >(loc_hk); const __timepunct& time_fr = use_facet<__timepunct >(loc_fr); const string empty; // create an ostream-derived object, cache the time_get facet iterator_type end; istringstream iss; const time_get& tim_get = use_facet >(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 char* all = "%a %A %b %B %c %d %H %I %j %m %M %p %s %U " "%w %W %x %X %y %Y %Z %%"; const char* date = "%A, the second of %B"; const char* date_ex = "%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("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("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("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("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("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("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("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("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 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& time_c = use_facet<__timepunct >(loc_c); const __timepunct& time_de = use_facet<__timepunct >(loc_de); const __timepunct& time_hk = use_facet<__timepunct >(loc_hk); const __timepunct& time_fr = use_facet<__timepunct >(loc_fr); const string empty; // create an ostream-derived object, cache the time_get facet iterator_type end; istringstream iss; const time_get& tim_get = use_facet >(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 char* all = "%a %A %b %B %c %d %H %I %j %m %M %p %s %U " "%w %W %x %X %y %Y %Z %%"; const char* date = "%A, the second of %B"; const char* date_ex = "%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("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("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("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("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("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("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 ); VERIFY( errorstate == ios_base::failbit ); VERIFY( *is_it05 == 'l'); // inspection of named locales, de_DE iss.imbue(loc_de); iss.str("April"); iterator_type is_it10(iss); tm time10; errorstate = good; tim_get.get_monthname(is_it10, end, iss, errorstate, &time10); VERIFY( time10.tm_mon == time_bday.tm_mon ); VERIFY( errorstate == ios_base::eofbit ); // inspection of named locales, en_HK iss.imbue(loc_hk); iss.str("April"); iterator_type is_it20(iss); tm time20; errorstate = good; tim_get.get_monthname(is_it20, end, iss, errorstate, &time20); VERIFY( time20.tm_mon == time_bday.tm_mon ); VERIFY( errorstate == ios_base::eofbit ); } void test04() { using namespace std; typedef time_base::dateorder dateorder; typedef istreambuf_iterator 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& time_c = use_facet<__timepunct >(loc_c); const __timepunct& time_de = use_facet<__timepunct >(loc_de); const __timepunct& time_hk = use_facet<__timepunct >(loc_hk); const __timepunct& time_fr = use_facet<__timepunct >(loc_fr); const string empty; // create an ostream-derived object, cache the time_get facet iterator_type end; istringstream iss; const time_get& tim_get = use_facet >(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 char* all = "%a %A %b %B %c %d %H %I %j %m %M %p %s %U " "%w %W %x %X %y %Y %Z %%"; const char* date = "%A, the second of %B"; const char* date_ex = "%Ex"; // iter_type // get_year(iter_type, iter_type, ios_base&, ios_base::iostate&, tm*) const // sanity checks for "C" locale iss.imbue(loc_c); iss.str("1971"); iterator_type is_it01(iss); tm time01; errorstate = good; tim_get.get_year(is_it01, end, iss, errorstate, &time01); VERIFY( time01.tm_year == time_bday.tm_year ); VERIFY( errorstate == ios_base::eofbit ); iss.str("1971 "); iterator_type is_it02(iss); tm time02; errorstate = good; tim_get.get_year(is_it02, end, iss, errorstate, &time02); VERIFY( time02.tm_year == time_bday.tm_year ); VERIFY( errorstate == good ); VERIFY( *is_it02 == ' '); iss.str("197d1 "); iterator_type is_it03(iss); tm time03; time03.tm_year = 3; errorstate = good; tim_get.get_year(is_it03, end, iss, errorstate, &time03); VERIFY( time03.tm_year == 3 ); VERIFY( errorstate == ios_base::failbit ); VERIFY( *is_it03 == 'd'); iss.str("71d71"); iterator_type is_it04(iss); tm time04; errorstate = good; tim_get.get_year(is_it04, end, iss, errorstate, &time04); VERIFY( time04.tm_year == time_bday.tm_year ); VERIFY( errorstate == good ); VERIFY( *is_it03 == 'd'); iss.str("71"); iterator_type is_it05(iss); tm time05; errorstate = good; tim_get.get_year(is_it05, end, iss, errorstate, &time05); VERIFY( time05.tm_year == time_bday.tm_year ); VERIFY( errorstate == ios_base::eofbit ); } void test05() { using namespace std; typedef time_base::dateorder dateorder; typedef istreambuf_iterator 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& time_c = use_facet<__timepunct >(loc_c); const __timepunct& time_de = use_facet<__timepunct >(loc_de); const __timepunct& time_hk = use_facet<__timepunct >(loc_hk); const __timepunct& time_fr = use_facet<__timepunct >(loc_fr); const string empty; // create an ostream-derived object, cache the time_get facet iterator_type end; istringstream iss; const time_get& tim_get = use_facet >(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 char* all = "%a %A %b %B %c %d %H %I %j %m %M %p %s %U " "%w %W %x %X %y %Y %Z %%"; const char* date = "%A, the second of %B"; const char* date_ex = "%Ex"; // iter_type // get_date(iter_type, iter_type, ios_base&, ios_base::iostate&, tm*) const // sanity checks for "C" locale iss.imbue(loc_c); iss.str("04/04/71"); iterator_type is_it01(iss); tm time01; errorstate = good; tim_get.get_date(is_it01, end, iss, errorstate, &time01); VERIFY( time01.tm_year == time_bday.tm_year ); VERIFY( time01.tm_mon == time_bday.tm_mon ); VERIFY( time01.tm_mday == time_bday.tm_mday ); VERIFY( errorstate == ios_base::eofbit ); iss.str("04/04/71 "); iterator_type is_it02(iss); tm time02; errorstate = good; tim_get.get_date(is_it02, end, iss, errorstate, &time02); VERIFY( time02.tm_year == time_bday.tm_year ); VERIFY( time02.tm_mon == time_bday.tm_mon ); VERIFY( time02.tm_mday == time_bday.tm_mday ); VERIFY( errorstate == good ); VERIFY( *is_it02 == ' '); iss.str("04/04d/71 "); iterator_type is_it03(iss); tm time03; time03.tm_year = 3; errorstate = good; tim_get.get_date(is_it03, end, iss, errorstate, &time03); VERIFY( time03.tm_year == 3 ); VERIFY( time03.tm_mon == time_bday.tm_mon ); VERIFY( time03.tm_mday == time_bday.tm_mday ); VERIFY( errorstate == ios_base::failbit ); VERIFY( *is_it03 == 'd'); // inspection of named locales, de_DE iss.imbue(loc_de); iss.str("04.04.1971"); iterator_type is_it10(iss); tm time10; errorstate = good; tim_get.get_date(is_it10, end, iss, errorstate, &time10); VERIFY( time10.tm_mon == time_bday.tm_mon ); VERIFY( time10.tm_mday == time_bday.tm_mday ); VERIFY( time10.tm_year == time_bday.tm_year ); VERIFY( errorstate == ios_base::eofbit ); // inspection of named locales, en_HK iss.imbue(loc_hk); iss.str("Sunday, April 04, 1971"); iterator_type is_it20(iss); tm time20; errorstate = good; tim_get.get_date(is_it20, end, iss, errorstate, &time20); VERIFY( time20.tm_mon == time_bday.tm_mon ); VERIFY( time20.tm_mday == time_bday.tm_mday ); VERIFY( time20.tm_year == time_bday.tm_year ); VERIFY( errorstate == ios_base::eofbit ); } void test06() { using namespace std; bool test = true; // Check time_get works with other iterators besides streambuf // input iterators. typedef string::const_iterator iter_type; typedef time_get time_get_type; const ios_base::iostate goodbit = ios_base::goodbit; const ios_base::iostate eofbit = ios_base::eofbit; ios_base::iostate err = goodbit; const locale loc_c = locale::classic(); // Cindy Sherman's Untitled Film Stills // June 26-September 2, 1997 const string str = "12:00:00 06/26/97 Tuesday September 1997 Cindy Sherman"; // Create "C" time objects const tm time_sanity = { 0, 0, 12, 26, 5, 97, 2 }; tm tm1; istringstream iss; iss.imbue(locale(loc_c, new time_get_type)); // Iterator advanced, state, output. const time_get_type& tg = use_facet(iss.getloc()); // 01 get_time // 02 get_date // 03 get_weekday // 04 get_monthname // 05 get_year // 01 get_time string res1; err = goodbit; iter_type end1 = tg.get_time(str.begin(), str.end(), iss, err, &tm1); string rem1(end1, str.end()); VERIFY( err == goodbit ); VERIFY( tm1.tm_sec == time_sanity.tm_sec ); VERIFY( tm1.tm_min == time_sanity.tm_min ); VERIFY( tm1.tm_hour == time_sanity.tm_hour ); VERIFY( rem1 == " 06/26/97 Tuesday September 1997 Cindy Sherman" ); // 02 get_date string res2; err = goodbit; // White space is not eaten, so manually increment past it. iter_type end2 = tg.get_date(++end1, str.end(), iss, err, &tm1); string rem2(end2, str.end()); VERIFY( err == goodbit ); VERIFY( tm1.tm_year == time_sanity.tm_year ); VERIFY( tm1.tm_mon == time_sanity.tm_mon ); VERIFY( tm1.tm_mday == time_sanity.tm_mday ); VERIFY( rem2 == " Tuesday September 1997 Cindy Sherman" ); // 03 get_weekday string res3; err = goodbit; // White space is not eaten, so manually increment past it. iter_type end3 = tg.get_weekday(++end2, str.end(), iss, err, &tm1); string rem3(end3, str.end()); VERIFY( err == goodbit ); VERIFY( tm1.tm_wday == time_sanity.tm_wday ); VERIFY( rem3 == " September 1997 Cindy Sherman" ); // 04 get_monthname string res4; err = goodbit; // White space is not eaten, so manually increment past it. iter_type end4 = tg.get_monthname(++end3, str.end(), iss, err, &tm1); string rem4(end4, str.end()); VERIFY( err == goodbit ); VERIFY( tm1.tm_mon == 8 ); VERIFY( rem4 == " 1997 Cindy Sherman" ); // 05 get_year string res5; err = goodbit; // White space is not eaten, so manually increment past it. iter_type end5 = tg.get_year(++end4, str.end(), iss, err, &tm1); string rem5(end5, str.end()); VERIFY( err == goodbit ); VERIFY( tm1.tm_year == time_sanity.tm_year ); VERIFY( rem5 == " Cindy Sherman" ); } // libstdc++/5280 void test07() { #ifdef _GLIBCPP_HAVE_SETENV // Set the global locale to non-"C". std::locale loc_de("de_DE"); std::locale::global(loc_de); // Set LANG environment variable to de_DE. const char* oldLANG = getenv("LANG"); if (!setenv("LANG", "de_DE", 1)) { test01(); test02(); test03(); test04(); test05(); test06(); setenv("LANG", oldLANG ? oldLANG : "", 1); } #endif } int main() { test01(); test02(); test03(); test04(); test05(); test06(); test07(); return 0; }