]>
git.saurik.com Git - apple/icu.git/blob - icuSources/samples/datefmt/main.cpp
1 /*************************************************************************
2 * © 2016 and later: Unicode, Inc. and others.
3 * License & terms of use: http://www.unicode.org/copyright.html#License
4 *************************************************************************
5 *************************************************************************
7 * Copyright (c) 1999-2003, International Business Machines Corporation and
8 * others. All Rights Reserved.
9 *************************************************************************/
11 #include "unicode/unistr.h"
12 #include "unicode/calendar.h"
13 #include "unicode/datefmt.h"
21 * If the ID supplied to TimeZone is not a valid system ID,
22 * TimeZone::createTimeZone() will return a GMT zone object. In order
23 * to detect this error, we check the ID of the returned zone against
24 * the ID we requested. If they don't match, we fail with an error.
26 TimeZone
* createZone(const UnicodeString
& id
) {
28 TimeZone
* zone
= TimeZone::createTimeZone(id
);
29 if (zone
->getID(str
) != id
) {
31 printf("Error: TimeZone::createTimeZone(");
33 printf(") returned zone with ID ");
41 int main(int argc
, char **argv
) {
46 UErrorCode status
= U_ZERO_ERROR
;
50 // The languages in which we will display the date
51 static char* LANGUAGE
[] = {
54 static const int32_t N_LANGUAGE
= sizeof(LANGUAGE
)/sizeof(LANGUAGE
[0]);
56 // The time zones in which we will display the time
57 static char* TIMEZONE
[] = {
58 "America/Los_Angeles",
63 static const int32_t N_TIMEZONE
= sizeof(TIMEZONE
)/sizeof(TIMEZONE
[0]);
66 cal
= Calendar::createInstance(status
);
67 check(status
, "Calendar::createInstance");
68 zone
= createZone("GMT"); // Create a GMT zone
69 cal
->adoptTimeZone(zone
);
71 cal
->set(1999, Calendar::JUNE
, 4);
72 date
= cal
->getTime(status
);
73 check(status
, "Calendar::getTime");
75 for (int32_t i
=0; i
<N_LANGUAGE
; ++i
) {
76 Locale
loc(LANGUAGE
[i
]);
78 // Create a formatter for DATE and TIME
79 fmt
= DateFormat::createDateTimeInstance(
80 DateFormat::kFull
, DateFormat::kFull
, loc
);
82 for (int32_t j
=0; j
<N_TIMEZONE
; ++j
) {
84 cal
->adoptTimeZone(createZone(TIMEZONE
[j
]));
85 fmt
->setCalendar(*cal
);
89 fmt
->format(date
, str
, status
);
91 // Display the formatted date string
92 printf("Date (%s, %s): ", LANGUAGE
[i
], TIMEZONE
[j
]);
100 printf("Exiting successfully\n");