2007-04-09 22:54:03 +00:00
|
|
|
/*
|
|
|
|
*******************************************************************************
|
|
|
|
* Copyright (C) 2007, International Business Machines Corporation and *
|
|
|
|
* others. All Rights Reserved. *
|
|
|
|
*******************************************************************************
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef RELDTFMT_H
|
|
|
|
#define RELDTFMT_H
|
|
|
|
|
|
|
|
#include "unicode/utypes.h"
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
* \brief C++ API: Format and parse relative dates and times.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if !UCONFIG_NO_FORMATTING
|
|
|
|
|
|
|
|
#include "unicode/datefmt.h"
|
|
|
|
|
|
|
|
U_NAMESPACE_BEGIN
|
|
|
|
|
|
|
|
// forward declarations
|
|
|
|
class MessageFormat;
|
|
|
|
|
|
|
|
// internal structure used for caching strings
|
|
|
|
struct URelativeString;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class is normally accessed using the kRelative or k...Relative values of EStyle as parameters to DateFormat::createDateInstance.
|
|
|
|
*
|
|
|
|
* Example:
|
|
|
|
* DateFormat *fullrelative = DateFormat::createDateInstance(DateFormat::kFullRelative, loc);
|
|
|
|
*
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
|
2007-06-03 06:08:46 +00:00
|
|
|
class RelativeDateFormat : public DateFormat {
|
2007-04-09 22:54:03 +00:00
|
|
|
public:
|
|
|
|
RelativeDateFormat( UDateFormatStyle timeStyle, UDateFormatStyle dateStyle, const Locale& locale, UErrorCode& status);
|
|
|
|
|
|
|
|
// overrides
|
|
|
|
/**
|
|
|
|
* Copy constructor.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
RelativeDateFormat(const RelativeDateFormat&);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assignment operator.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
RelativeDateFormat& operator=(const RelativeDateFormat&);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Destructor.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual ~RelativeDateFormat();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clone this Format object polymorphically. The caller owns the result and
|
|
|
|
* should delete it when done.
|
|
|
|
* @return A copy of the object.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual Format* clone(void) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return true if the given Format objects are semantically equal. Objects
|
|
|
|
* of different subclasses are considered unequal.
|
|
|
|
* @param other the object to be compared with.
|
|
|
|
* @return true if the given Format objects are semantically equal.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual UBool operator==(const Format& other) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format a date or time, which is the standard millis since 24:00 GMT, Jan
|
|
|
|
* 1, 1970. Overrides DateFormat pure virtual method.
|
|
|
|
* <P>
|
|
|
|
* Example: using the US locale: "yyyy.MM.dd e 'at' HH:mm:ss zzz" ->>
|
|
|
|
* 1996.07.10 AD at 15:08:56 PDT
|
|
|
|
*
|
|
|
|
* @param cal Calendar set to the date and time to be formatted
|
|
|
|
* into a date/time string.
|
|
|
|
* @param appendTo Output parameter to receive result.
|
|
|
|
* Result is appended to existing contents.
|
|
|
|
* @param pos The formatting position. On input: an alignment field,
|
|
|
|
* if desired. On output: the offsets of the alignment field.
|
|
|
|
* @return Reference to 'appendTo' parameter.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual UnicodeString& format( Calendar& cal,
|
|
|
|
UnicodeString& appendTo,
|
|
|
|
FieldPosition& pos) const;
|
|
|
|
|
2007-04-10 22:57:25 +00:00
|
|
|
/**
|
|
|
|
* Format an object to produce a string. This method handles Formattable
|
|
|
|
* objects with a UDate type. If a the Formattable object type is not a Date,
|
|
|
|
* then it returns a failing UErrorCode.
|
|
|
|
*
|
|
|
|
* @param obj The object to format. Must be a Date.
|
|
|
|
* @param appendTo Output parameter to receive result.
|
|
|
|
* Result is appended to existing contents.
|
|
|
|
* @param pos On input: an alignment field, if desired.
|
|
|
|
* On output: the offsets of the alignment field.
|
|
|
|
* @param status Output param filled with success/failure status.
|
|
|
|
* @return Reference to 'appendTo' parameter.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual UnicodeString& format(const Formattable& obj,
|
|
|
|
UnicodeString& appendTo,
|
|
|
|
FieldPosition& pos,
|
|
|
|
UErrorCode& status) const;
|
|
|
|
|
2007-04-09 22:54:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse a date/time string beginning at the given parse position. For
|
|
|
|
* example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a Date
|
|
|
|
* that is equivalent to Date(837039928046).
|
|
|
|
* <P>
|
|
|
|
* By default, parsing is lenient: If the input is not in the form used by
|
|
|
|
* this object's format method but can still be parsed as a date, then the
|
|
|
|
* parse succeeds. Clients may insist on strict adherence to the format by
|
|
|
|
* calling setLenient(false).
|
|
|
|
*
|
|
|
|
* @param text The date/time string to be parsed
|
|
|
|
* @param cal a Calendar set to the date and time to be formatted
|
|
|
|
* into a date/time string.
|
|
|
|
* @param pos On input, the position at which to start parsing; on
|
|
|
|
* output, the position at which parsing terminated, or the
|
|
|
|
* start position if the parse failed.
|
|
|
|
* @return A valid UDate if the input could be parsed.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual void parse( const UnicodeString& text,
|
|
|
|
Calendar& cal,
|
2007-04-10 22:57:25 +00:00
|
|
|
ParsePosition& pos) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse a date/time string starting at the given parse position. For
|
|
|
|
* example, a time text "07/10/96 4:5 PM, PDT" will be parsed into a Date
|
|
|
|
* that is equivalent to Date(837039928046).
|
|
|
|
* <P>
|
|
|
|
* By default, parsing is lenient: If the input is not in the form used by
|
|
|
|
* this object's format method but can still be parsed as a date, then the
|
|
|
|
* parse succeeds. Clients may insist on strict adherence to the format by
|
|
|
|
* calling setLenient(false).
|
|
|
|
*
|
|
|
|
* @see DateFormat::setLenient(boolean)
|
|
|
|
*
|
|
|
|
* @param text The date/time string to be parsed
|
|
|
|
* @param pos On input, the position at which to start parsing; on
|
|
|
|
* output, the position at which parsing terminated, or the
|
|
|
|
* start position if the parse failed.
|
|
|
|
* @return A valid UDate if the input could be parsed.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
UDate parse( const UnicodeString& text,
|
|
|
|
ParsePosition& pos) const;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse a date/time string. For example, a time text "07/10/96 4:5 PM, PDT"
|
|
|
|
* will be parsed into a UDate that is equivalent to Date(837039928046).
|
|
|
|
* Parsing begins at the beginning of the string and proceeds as far as
|
|
|
|
* possible. Assuming no parse errors were encountered, this function
|
|
|
|
* doesn't return any information about how much of the string was consumed
|
|
|
|
* by the parsing. If you need that information, use the version of
|
|
|
|
* parse() that takes a ParsePosition.
|
|
|
|
*
|
|
|
|
* @param text The date/time string to be parsed
|
|
|
|
* @param status Filled in with U_ZERO_ERROR if the parse was successful, and with
|
|
|
|
* an error value if there was a parse error.
|
|
|
|
* @return A valid UDate if the input could be parsed.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual UDate parse( const UnicodeString& text,
|
|
|
|
UErrorCode& status) const;
|
|
|
|
|
|
|
|
|
|
|
|
|
2007-04-09 22:54:03 +00:00
|
|
|
private:
|
|
|
|
DateFormat *fDateFormat; // the held date format
|
|
|
|
DateFormat *fTimeFormat; // the held time format
|
|
|
|
MessageFormat *fCombinedFormat; // the {0} {1} format.
|
|
|
|
|
2007-04-10 22:57:25 +00:00
|
|
|
UDateFormatStyle fDateStyle;
|
|
|
|
UDateFormatStyle fTimeStyle;
|
|
|
|
Locale fLocale;
|
2007-04-09 22:54:03 +00:00
|
|
|
|
2007-04-10 22:57:25 +00:00
|
|
|
int32_t fDayMin; // day id of lowest #
|
|
|
|
int32_t fDayMax; // day id of highest #
|
|
|
|
int32_t fDatesLen; // Length of array
|
|
|
|
URelativeString *fDates; // array of strings
|
2007-04-09 22:54:03 +00:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the string at a specific offset.
|
|
|
|
* @param day day offset ( -1, 0, 1, etc.. )
|
|
|
|
* @param len on output, length of string.
|
|
|
|
* @return the string, or NULL if none at that location.
|
|
|
|
*/
|
|
|
|
const UChar *getStringForDay(int32_t day, int32_t &len, UErrorCode &status) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Load the Date string array
|
|
|
|
*/
|
2007-06-15 02:35:33 +00:00
|
|
|
void loadDates(UErrorCode &status);
|
2007-04-09 22:54:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return the number of days in "until-now"
|
|
|
|
*/
|
|
|
|
static int32_t dayDifference(Calendar &until, UErrorCode &status);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* initializes fCalendar from parameters. Returns fCalendar as a convenience.
|
|
|
|
* @param adoptZone Zone to be adopted, or NULL for TimeZone::createDefault().
|
|
|
|
* @param locale Locale of the calendar
|
|
|
|
* @param status Error code
|
|
|
|
* @return the newly constructed fCalendar
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
Calendar* initializeCalendar(TimeZone* adoptZone, const Locale& locale, UErrorCode& status);
|
|
|
|
|
|
|
|
public:
|
|
|
|
/**
|
|
|
|
* Return the class ID for this class. This is useful only for comparing to
|
|
|
|
* a return value from getDynamicClassID(). For example:
|
|
|
|
* <pre>
|
|
|
|
* . Base* polymorphic_pointer = createPolymorphicObject();
|
|
|
|
* . if (polymorphic_pointer->getDynamicClassID() ==
|
|
|
|
* . erived::getStaticClassID()) ...
|
|
|
|
* </pre>
|
|
|
|
* @return The class ID for all objects of this class.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
2007-06-03 06:08:46 +00:00
|
|
|
U_I18N_API static UClassID U_EXPORT2 getStaticClassID(void);
|
2007-04-09 22:54:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
|
|
|
|
* method is to implement a simple version of RTTI, since not all C++
|
|
|
|
* compilers support genuine RTTI. Polymorphic operator==() and clone()
|
|
|
|
* methods call this method.
|
|
|
|
*
|
|
|
|
* @return The class ID for this object. All objects of a
|
|
|
|
* given class have the same class ID. Objects of
|
|
|
|
* other classes have different class IDs.
|
|
|
|
* @draft ICU 3.8
|
|
|
|
*/
|
|
|
|
virtual UClassID getDynamicClassID(void) const;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
U_NAMESPACE_END
|
|
|
|
|
|
|
|
#endif /* #if !UCONFIG_NO_FORMATTING */
|
|
|
|
|
|
|
|
#endif // RELDTFMT_H
|
|
|
|
//eof
|