Home | History | Annotate | Download | only in i18n
      1 /*
      2 ********************************************************************************
      3 *   Copyright (C) 2005-2009, International Business Machines
      4 *   Corporation and others.  All Rights Reserved.
      5 ********************************************************************************
      6 *
      7 * File WINDTFMT.H
      8 *
      9 ********************************************************************************
     10 */
     11 
     12 #ifndef __WINDTFMT
     13 #define __WINDTFMT
     14 
     15 #include "unicode/utypes.h"
     16 
     17 #ifdef U_WINDOWS
     18 
     19 #if !UCONFIG_NO_FORMATTING
     20 
     21 #include "unicode/format.h"
     22 #include "unicode/datefmt.h"
     23 #include "unicode/calendar.h"
     24 #include "unicode/ustring.h"
     25 #include "unicode/locid.h"
     26 
     27 /**
     28  * \file
     29  * \brief C++ API: Format dates using Windows API.
     30  */
     31 
     32 U_CDECL_BEGIN
     33 // Forward declarations for Windows types...
     34 typedef struct _SYSTEMTIME SYSTEMTIME;
     35 typedef struct _TIME_ZONE_INFORMATION TIME_ZONE_INFORMATION;
     36 U_CDECL_END
     37 
     38 U_NAMESPACE_BEGIN
     39 
     40 class Win32DateFormat : public DateFormat
     41 {
     42 public:
     43     Win32DateFormat(DateFormat::EStyle timeStyle, DateFormat::EStyle dateStyle, const Locale &locale, UErrorCode &status);
     44 
     45     Win32DateFormat(const Win32DateFormat &other);
     46 
     47     virtual ~Win32DateFormat();
     48 
     49     virtual Format *clone(void) const;
     50 
     51     Win32DateFormat &operator=(const Win32DateFormat &other);
     52 
     53     UnicodeString &format(Calendar &cal, UnicodeString &appendTo, FieldPosition &pos) const;
     54 
     55     UnicodeString& format(UDate date, UnicodeString& appendTo) const;
     56 
     57     void parse(const UnicodeString& text, Calendar& cal, ParsePosition& pos) const;
     58 
     59     /**
     60      * Set the calendar to be used by this date format. Initially, the default
     61      * calendar for the specified or default locale is used.  The caller should
     62      * not delete the Calendar object after it is adopted by this call.
     63      *
     64      * @param calendarToAdopt    Calendar object to be adopted.
     65      * @draft ICU 3.6
     66      */
     67     virtual void adoptCalendar(Calendar* calendarToAdopt);
     68 
     69     /**
     70      * Set the calendar to be used by this date format. Initially, the default
     71      * calendar for the specified or default locale is used.
     72      *
     73      * @param newCalendar Calendar object to be set.
     74      *
     75      * @draft ICU 3.6
     76      */
     77     virtual void setCalendar(const Calendar& newCalendar);
     78 
     79     /**
     80      * Sets the time zone for the calendar of this DateFormat object. The caller
     81      * no longer owns the TimeZone object and should not delete it after this call.
     82      *
     83      * @param zoneToAdopt the TimeZone to be adopted.
     84      *
     85      * @draft ICU 3.6
     86      */
     87     virtual void adoptTimeZone(TimeZone* zoneToAdopt);
     88 
     89     /**
     90      * Sets the time zone for the calendar of this DateFormat object.
     91      * @param zone the new time zone.
     92      *
     93      * @draft ICU 3.6
     94      */
     95     virtual void setTimeZone(const TimeZone& zone);
     96 
     97     /**
     98      * Return the class ID for this class. This is useful only for comparing to
     99      * a return value from getDynamicClassID(). For example:
    100      * <pre>
    101      * .   Base* polymorphic_pointer = createPolymorphicObject();
    102      * .   if (polymorphic_pointer->getDynamicClassID() ==
    103      * .       erived::getStaticClassID()) ...
    104      * </pre>
    105      * @return          The class ID for all objects of this class.
    106      * @draft ICU 3.6
    107      */
    108     U_I18N_API static UClassID U_EXPORT2 getStaticClassID(void);
    109 
    110     /**
    111      * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
    112      * method is to implement a simple version of RTTI, since not all C++
    113      * compilers support genuine RTTI. Polymorphic operator==() and clone()
    114      * methods call this method.
    115      *
    116      * @return          The class ID for this object. All objects of a
    117      *                  given class have the same class ID.  Objects of
    118      *                  other classes have different class IDs.
    119      * @draft ICU 3.6
    120      */
    121     virtual UClassID getDynamicClassID(void) const;
    122 
    123 private:
    124     void formatDate(const SYSTEMTIME *st, UnicodeString &appendTo) const;
    125     void formatTime(const SYSTEMTIME *st, UnicodeString &appendTo) const;
    126 
    127     UnicodeString setTimeZoneInfo(TIME_ZONE_INFORMATION *tzi, const TimeZone &zone) const;
    128     UnicodeString* getTimeDateFormat(const Calendar *cal, const Locale *locale, UErrorCode &status) const;
    129 
    130     UnicodeString *fDateTimeMsg;
    131     DateFormat::EStyle fTimeStyle;
    132     DateFormat::EStyle fDateStyle;
    133     const Locale *fLocale;
    134     int32_t fLCID;
    135     UnicodeString fZoneID;
    136     TIME_ZONE_INFORMATION *fTZI;
    137 };
    138 
    139 inline UnicodeString &Win32DateFormat::format(UDate date, UnicodeString& appendTo) const {
    140     return DateFormat::format(date, appendTo);
    141 }
    142 
    143 U_NAMESPACE_END
    144 
    145 #endif /* #if !UCONFIG_NO_FORMATTING */
    146 
    147 #endif // #ifdef U_WINDOWS
    148 
    149 #endif // __WINDTFMT
    150