91 lines
2.5 KiB
C++
91 lines
2.5 KiB
C++
|
#include "unicode/unistr.h"
|
||
|
#include "unicode/calendar.h"
|
||
|
#include "unicode/datefmt.h"
|
||
|
#include <stdio.h>
|
||
|
#include <stdlib.h>
|
||
|
#include "util.h"
|
||
|
|
||
|
/**
|
||
|
* If the ID supplied to TimeZone is not a valid system ID,
|
||
|
* TimeZone::createTimeZone() will return a GMT zone object. In order
|
||
|
* to detect this error, we check the ID of the returned zone against
|
||
|
* the ID we requested. If they don't match, we fail with an error.
|
||
|
*/
|
||
|
TimeZone* createZone(const UnicodeString& id) {
|
||
|
UnicodeString str;
|
||
|
TimeZone* zone = TimeZone::createTimeZone(id);
|
||
|
if (zone->getID(str) != id) {
|
||
|
delete zone;
|
||
|
printf("Error: TimeZone::createTimeZone(");
|
||
|
uprintf(id);
|
||
|
printf(") returned zone with ID ");
|
||
|
uprintf(str);
|
||
|
printf("\n");
|
||
|
exit(1);
|
||
|
}
|
||
|
return zone;
|
||
|
}
|
||
|
|
||
|
int main(int argc, char **argv) {
|
||
|
|
||
|
Calendar *cal;
|
||
|
TimeZone *zone;
|
||
|
DateFormat *fmt;
|
||
|
UErrorCode status = U_ZERO_ERROR;
|
||
|
UnicodeString str;
|
||
|
UDate date;
|
||
|
|
||
|
// The languages in which we will display the date
|
||
|
static char* LANGUAGE[] = {
|
||
|
"en", "de", "fr"
|
||
|
};
|
||
|
static const int32_t N_LANGUAGE = sizeof(LANGUAGE)/sizeof(LANGUAGE[0]);
|
||
|
|
||
|
// The time zones in which we will display the time
|
||
|
static char* TIMEZONE[] = {
|
||
|
"America/Los_Angeles",
|
||
|
"America/New_York",
|
||
|
"Europe/Paris",
|
||
|
"Europe/Berlin"
|
||
|
};
|
||
|
static const int32_t N_TIMEZONE = sizeof(TIMEZONE)/sizeof(TIMEZONE[0]);
|
||
|
|
||
|
// Create a calendar
|
||
|
cal = Calendar::createInstance(status);
|
||
|
check(status, "Calendar::createInstance");
|
||
|
zone = createZone("GMT"); // Create a GMT zone
|
||
|
cal->adoptTimeZone(zone);
|
||
|
cal->clear();
|
||
|
cal->set(1999, Calendar::JUNE, 4);
|
||
|
date = cal->getTime(status);
|
||
|
check(status, "Calendar::getTime");
|
||
|
|
||
|
for (int32_t i=0; i<N_LANGUAGE; ++i) {
|
||
|
Locale loc(LANGUAGE[i]);
|
||
|
|
||
|
// Create a formatter for DATE and TIME
|
||
|
fmt = DateFormat::createDateTimeInstance(
|
||
|
DateFormat::kFull, DateFormat::kFull, loc);
|
||
|
|
||
|
for (int32_t j=0; j<N_TIMEZONE; ++j) {
|
||
|
|
||
|
cal->adoptTimeZone(createZone(TIMEZONE[j]));
|
||
|
fmt->setCalendar(*cal);
|
||
|
|
||
|
// Format the date
|
||
|
str.remove();
|
||
|
fmt->format(date, str, status);
|
||
|
|
||
|
// Display the formatted date string
|
||
|
printf("Date (%s, %s): ", LANGUAGE[i], TIMEZONE[j]);
|
||
|
uprintf(escape(str));
|
||
|
printf("\n\n");
|
||
|
}
|
||
|
|
||
|
delete fmt;
|
||
|
}
|
||
|
|
||
|
printf("Exiting successfully\n");
|
||
|
return 0;
|
||
|
}
|