14 #ifndef __DTPTNGEN_H__
15 #define __DTPTNGEN_H__
19 #if U_SHOW_CPLUSPLUS_API
38 class DateTimeMatcher;
42 class SharedDateTimePatternGenerator;
77 #ifndef U_HIDE_INTERNAL_API
222 #ifndef U_HIDE_INTERNAL_API
343 #if !UCONFIG_NO_FORMATTING
507 #ifndef U_HIDE_INTERNAL_API
543 #if !UCONFIG_NO_FORMATTING
602 DateTimeMatcher* dtMatcher;
603 DistanceInfo *distanceInfo;
604 PatternMap *patternMap;
609 DateTimeMatcher *skipMatcher;
610 Hashtable *fAvailableFormatKeyHash;
612 char16_t fDefaultHourFormatChar;
614 int32_t fAllowedHourFormats[7];
624 kDTPGFixFractionalSeconds = 1,
625 kDTPGSkeletonUsesCapJ = 2
633 void getCalendarTypeToUse(
const Locale& locale, CharString& destination,
UErrorCode& err);
647 const UnicodeString* getBestRaw(DateTimeMatcher& source, int32_t includeMask, DistanceInfo* missingFields,
UErrorCode& status,
const PtnSkeleton** specifiedSkeletonPtr =
nullptr);
650 int32_t getTopBitNumber(int32_t foundMask)
const;
653 void copyHashtable(Hashtable *other,
UErrorCode &status);
658 struct U_HIDDEN AppendItemFormatsSink;
659 struct U_HIDDEN AppendItemNamesSink;
660 struct U_HIDDEN AvailableFormatsSink;
This class provides flexible generation of date format patterns, like "yy-MM-dd".
static U_I18N_API DateTimePatternGenerator * createEmptyInstance(UErrorCode &status)
Create an empty generator, to be constructed with addPattern(...) etc.
U_I18N_API UnicodeString replaceFieldTypes(const UnicodeString &pattern, const UnicodeString &skeleton, UErrorCode &status)
Adjusts the field types (width and subtype) of a pattern to match what is in a skeleton.
static U_I18N_API DateTimePatternGenerator * createInstance(const Locale &uLocale, UErrorCode &status)
Construct a flexible generator according to data for a given locale.
static U_I18N_API DateTimePatternGenerator * createInstanceNoStdPat(const Locale &uLocale, UErrorCode &status)
For ICU use only.
static U_I18N_API UnicodeString staticGetBaseSkeleton(const UnicodeString &pattern, UErrorCode &status)
Utility to return a unique base skeleton from a given pattern.
U_I18N_API void setDecimal(const UnicodeString &decimal)
The decimal value is used in formatting fractions of seconds.
U_I18N_API UDateFormatHourCycle getDefaultHourCycle(UErrorCode &status) const
Get the default hour cycle for a locale.
U_I18N_API UnicodeString replaceFieldTypes(const UnicodeString &pattern, const UnicodeString &skeleton, UDateTimePatternMatchOptions options, UErrorCode &status)
Adjusts the field types (width and subtype) of a pattern to match what is in a skeleton.
U_I18N_API const UnicodeString & getAppendItemFormat(UDateTimePatternField field) const
Getter corresponding to setAppendItemFormat.
U_I18N_API UDateTimePatternConflict addPatternWithSkeleton(const UnicodeString &pattern, const UnicodeString &skeletonToUse, UBool override, UnicodeString &conflictingPattern, UErrorCode &status)
Like addPattern, but associates the pattern with the given skeleton.
U_I18N_API bool operator==(const DateTimePatternGenerator &other) const
Return true if another object is semantically equal to this one.
U_I18N_API const UnicodeString & getDecimal() const
Getter corresponding to setDecimal.
U_I18N_API UnicodeString getFieldDisplayName(UDateTimePatternField field, UDateTimePGDisplayWidth width) const
The general interface to get a display name for a particular date/time field, in one of several possi...
U_I18N_API const UnicodeString & getDateTimeFormat(UDateFormatStyle style, UErrorCode &status) const
Getter corresponding to setDateTimeFormat.
U_I18N_API bool operator!=(const DateTimePatternGenerator &other) const
Return true if another object is semantically unequal to this one.
U_I18N_API DateTimePatternGenerator * clone() const
Clone DateTimePatternGenerator object.
static U_I18N_API UnicodeString staticGetSkeleton(const UnicodeString &pattern, UErrorCode &status)
Utility to return a unique skeleton from a given pattern.
U_I18N_API StringEnumeration * getRedundants(UErrorCode &status)
Return a list of redundant patterns are those which if removed, make no difference in the resulting g...
static U_I18N_API UClassID getStaticClassID()
ICU "poor man's RTTI", returns a UClassID for this class.
static U_I18N_API DateTimePatternGenerator * createInstance(UErrorCode &status)
Construct a flexible generator according to default locale.
U_I18N_API const UnicodeString & getPatternForSkeleton(const UnicodeString &skeleton) const
Get the pattern corresponding to a given skeleton.
U_I18N_API UnicodeString getBestPattern(const UnicodeString &skeleton, UDateTimePatternMatchOptions options, UErrorCode &status)
Return the best pattern matching the input skeleton.
U_I18N_API const UnicodeString & getDateTimeFormat() const
Getter corresponding to setDateTimeFormat.
U_I18N_API UnicodeString getSkeleton(const UnicodeString &pattern, UErrorCode &status)
Utility to return a unique skeleton from a given pattern.
virtual U_I18N_API ~DateTimePatternGenerator()
Destructor.
U_I18N_API UnicodeString getBestPattern(const UnicodeString &skeleton, UErrorCode &status)
Return the best pattern matching the input skeleton.
U_I18N_API void setAppendItemName(UDateTimePatternField field, const UnicodeString &value)
Sets the names of field, eg "era" in English for ERA.
U_I18N_API StringEnumeration * getBaseSkeletons(UErrorCode &status) const
Return a list of all the base skeletons (in canonical form) from this class.
U_I18N_API void setDateTimeFormat(UDateFormatStyle style, const UnicodeString &dateTimeFormat, UErrorCode &status)
dateTimeFormats are message patterns used to compose combinations of date and time patterns.
U_I18N_API void setDateTimeFormat(const UnicodeString &dateTimeFormat)
The DateTimeFormat is a message format pattern used to compose date and time patterns.
U_I18N_API const UnicodeString & getAppendItemName(UDateTimePatternField field) const
Getter corresponding to setAppendItemNames.
U_I18N_API StringEnumeration * getSkeletons(UErrorCode &status) const
Return a list of all the skeletons (in canonical form) from this class.
U_I18N_API UDateTimePatternConflict addPattern(const UnicodeString &pattern, UBool override, UnicodeString &conflictingPattern, UErrorCode &status)
Adds a pattern to the generator.
U_I18N_API UnicodeString getBaseSkeleton(const UnicodeString &pattern, UErrorCode &status)
Utility to return a unique base skeleton from a given pattern.
virtual U_I18N_API UClassID getDynamicClassID() const override
ICU "poor man's RTTI", returns a UClassID for the actual class.
U_I18N_API void setAppendItemFormat(UDateTimePatternField field, const UnicodeString &value)
An AppendItem format is a pattern used to append a field if there is no good match.
A Locale object represents a specific geographical, political, or cultural region.
Base class for 'pure' C++ implementations of uenum api.
UObject is the common ICU "boilerplate" class.
UnicodeString is a string class that stores Unicode characters directly and provides similar function...
C++ API: Abstract class for converting dates.
C++ API: Locale ID object.
UDateFormatStyle
The possible date/time format styles.
UDateFormatHourCycle
Hour Cycle.
C API: Wrapper for icu::DateTimePatternGenerator (unicode/dtptngen.h).
UDateTimePGDisplayWidth
Field display name width constants for udatpg_getFieldDisplayName().
UDateTimePatternConflict
Status return values from udatpg_addPattern().
UDateTimePatternMatchOptions
Masks to control forcing the length of specified fields in the returned pattern to match those in the...
@ UDATPG_MATCH_NO_OPTIONS
UDateTimePatternField
Field number constants for udatpg_getAppendItemFormats() and similar functions.
@ UDATPG_FIELD_COUNT
One more than the highest normal UDateTimePatternField value.
int8_t UBool
The ICU boolean type, a signed-byte integer.
void * UClassID
UClassID is used to identify classes without using the compiler's RTTI.
Basic definitions for ICU, for both C and C++ APIs.
UErrorCode
Standard ICU4C error code type, a substitute for exceptions.
#define U_I18N_API_CLASS
Set to export library symbols from inside the i18n library, and to import them from outside,...
#define U_I18N_API
Set to export library symbols from inside the i18n library, and to import them from outside.