1 /********************************************************************
2 * COPYRIGHT:
3 * Copyright (c) 1999-2002, International Business Machines Corporation and
4 * others. All Rights Reserved.
5 ********************************************************************/
6
7 #include "unicode/unistr.h"
8 #include "unicode/calendar.h"
9 #include "unicode/datefmt.h"
10 #include <stdio.h>
11 #include <stdlib.h>
12 #include "util.h"
13
14 /**
15 * If the ID supplied to TimeZone is not a valid system ID,
16 * TimeZone::createTimeZone() will return a GMT zone object. In order
17 * to detect this error, we check the ID of the returned zone against
18 * the ID we requested. If they don't match, we fail with an error.
19 */
createZone(const UnicodeString & id)20 TimeZone* createZone(const UnicodeString& id) {
21 UnicodeString str;
22 TimeZone* zone = TimeZone::createTimeZone(id);
23 if (zone->getID(str) != id) {
24 delete zone;
25 printf("Error: TimeZone::createTimeZone(");
26 uprintf(id);
27 printf(") returned zone with ID ");
28 uprintf(str);
29 printf("\n");
30 exit(1);
31 }
32 return zone;
33 }
34
main(int argc,char ** argv)35 int main(int argc, char **argv) {
36
37 Calendar *cal;
38 TimeZone *zone;
39 DateFormat *fmt;
40 UErrorCode status = U_ZERO_ERROR;
41 UnicodeString str;
42 UDate date;
43
44 // The languages in which we will display the date
45 static char* LANGUAGE[] = {
46 "en", "de", "fr"
47 };
48 static const int32_t N_LANGUAGE = sizeof(LANGUAGE)/sizeof(LANGUAGE[0]);
49
50 // The time zones in which we will display the time
51 static char* TIMEZONE[] = {
52 "America/Los_Angeles",
53 "America/New_York",
54 "Europe/Paris",
55 "Europe/Berlin"
56 };
57 static const int32_t N_TIMEZONE = sizeof(TIMEZONE)/sizeof(TIMEZONE[0]);
58
59 // Create a calendar
60 cal = Calendar::createInstance(status);
61 check(status, "Calendar::createInstance");
62 zone = createZone("GMT"); // Create a GMT zone
63 cal->adoptTimeZone(zone);
64 cal->clear();
65 cal->set(1999, Calendar::JUNE, 4);
66 date = cal->getTime(status);
67 check(status, "Calendar::getTime");
68
69 for (int32_t i=0; i<N_LANGUAGE; ++i) {
70 Locale loc(LANGUAGE[i]);
71
72 // Create a formatter for DATE and TIME
73 fmt = DateFormat::createDateTimeInstance(
74 DateFormat::kFull, DateFormat::kFull, loc);
75
76 for (int32_t j=0; j<N_TIMEZONE; ++j) {
77
78 cal->adoptTimeZone(createZone(TIMEZONE[j]));
79 fmt->setCalendar(*cal);
80
81 // Format the date
82 str.remove();
83 fmt->format(date, str, status);
84
85 // Display the formatted date string
86 printf("Date (%s, %s): ", LANGUAGE[i], TIMEZONE[j]);
87 uprintf(escape(str));
88 printf("\n\n");
89 }
90
91 delete fmt;
92 }
93
94 printf("Exiting successfully\n");
95 return 0;
96 }
97