24 #if U_SHOW_CPLUSPLUS_API 31 #if !UCONFIG_NO_FORMATTING 48 class AppendableWrapper;
347 #ifndef U_HIDE_OBSOLETE_API 497 return msgPattern.getApostropheMode();
526 U_I18N_API virtual void adoptFormats(
Format** formatsToAdopt, int32_t count);
558 U_I18N_API virtual void adoptFormat(int32_t formatNumber,
Format* formatToAdopt);
569 U_I18N_API virtual void setFormat(int32_t formatNumber,
const Format& format);
756 int32_t& count)
const;
823 #ifndef U_HIDE_INTERNAL_API 863 #ifndef U_HIDE_INTERNAL_API 874 U_I18N_API static UBool equalFormats(
const void* left,
const void* right);
882 int32_t formatAliasesCapacity;
892 class PluralSelectorProvider :
public PluralFormat::PluralSelector {
895 virtual ~PluralSelectorProvider();
913 Formattable::Type* argTypes;
914 int32_t argTypeCount;
915 int32_t argTypeCapacity;
922 UBool hasArgTypeConflicts;
934 NumberFormat* defaultNumberFormat;
935 DateFormat* defaultDateFormat;
940 PluralSelectorProvider pluralProvider;
941 PluralSelectorProvider ordinalProvider;
947 const NumberFormat* getDefaultNumberFormat(
UErrorCode&)
const;
948 const DateFormat* getDefaultDateFormat(
UErrorCode&)
const;
956 static int32_t findKeyword(
const UnicodeString& s,
957 const char16_t *
const *list);
964 UnicodeString&
format(
const Formattable* arguments,
965 const UnicodeString *argumentNames,
967 UnicodeString& appendTo,
988 void format(int32_t msgStart,
989 const void *plNumber,
990 const Formattable* arguments,
991 const UnicodeString *argumentNames,
993 AppendableWrapper& appendTo,
997 UnicodeString getArgName(int32_t partIndex);
999 void setArgStartFormat(int32_t argStart, Format* formatter,
UErrorCode& status);
1001 void setCustomArgStartFormat(int32_t argStart, Format* formatter,
UErrorCode& status);
1003 int32_t nextTopLevelArgStart(int32_t partIndex)
const;
1005 UBool argNameMatches(int32_t partIndex,
const UnicodeString& argName, int32_t argNumber);
1007 void cacheExplicitFormats(
UErrorCode& status);
1009 Format* createAppropriateFormat(UnicodeString& type,
1010 UnicodeString& style,
1011 Formattable::Type& formattableType,
1015 const Formattable* getArgFromListByName(
const Formattable* arguments,
1016 const UnicodeString *argumentNames,
1017 int32_t cnt, UnicodeString& name)
const;
1019 Formattable* parse(int32_t msgStart,
1020 const UnicodeString& source,
1025 FieldPosition* updateMetaData(AppendableWrapper& dest, int32_t prevLength,
1026 FieldPosition* fp,
const Formattable* argId)
const;
1033 int32_t findOtherSubMessage(int32_t partIndex)
const;
1040 int32_t findFirstPluralNumberArg(int32_t msgStart,
const UnicodeString &argName)
const;
1042 Format* getCachedFormatter(int32_t argumentNumber)
const;
1044 UnicodeString getLiteralStringUntilNextArgument(int32_t from)
const;
1046 void copyObjects(
const MessageFormat& that,
UErrorCode& ec);
1048 void formatComplexSubMessage(int32_t msgStart,
1049 const void *plNumber,
1050 const Formattable* arguments,
1051 const UnicodeString *argumentNames,
1053 AppendableWrapper& appendTo,
1059 NumberFormat* createIntegerFormat(
const Locale& locale,
UErrorCode& status)
const;
1068 const Formattable::Type* getArgTypeList(int32_t& listCount)
const {
1069 listCount = argTypeCount;
1076 void resetPattern();
1082 class DummyFormat :
public Format {
1084 virtual bool operator==(
const Format&)
const override;
1085 virtual DummyFormat* clone()
const override;
1086 virtual UnicodeString& format(
const Formattable& obj,
1087 UnicodeString& appendTo,
1089 virtual UnicodeString& format(
const Formattable&,
1090 UnicodeString& appendTo,
1093 virtual UnicodeString& format(
const Formattable& obj,
1094 UnicodeString& appendTo,
1095 FieldPositionIterator* posIter,
1097 virtual void parseObject(
const UnicodeString&,
1099 ParsePosition&)
const override;
1102 friend class MessageFormatAdapter;
struct UHashtable UHashtable
U_COMMON_API UBool operator==(const StringPiece &x, const StringPiece &y)
Global operator == for StringPiece.
void * UClassID
UClassID is used to identify classes without using the compiler's RTTI.
C++ API: PluralFormat object.
Base class for 'pure' C++ implementations of uenum api.
C++ API: PluralRules object.
Defines rules for mapping non-negative numeric values onto a small set of keywords.
Parses and represents ICU MessageFormat patterns.
#define U_CDECL_BEGIN
This is used to begin a declaration of a library private ICU C API.
#define U_I18N_API
Set to export library symbols from inside the i18n library, and to import them from outside...
#define U_I18N_API_CLASS
Set to export library symbols from inside the i18n library, and to import them from outside...
virtual UClassID getDynamicClassID() const
ICU4C "poor man's RTTI", returns a UClassID for the actual ICU class.
#define U_CDECL_END
This is used to end a declaration of a library private ICU C API.
C API: Parse Error Information.
UErrorCode
Standard ICU4C error code type, a substitute for exceptions.
FieldPosition is a simple class used by Format and its subclasses to identify fields in formatted out...
UPluralType
Type of plurals and PluralRules.
ParsePosition is a simple class used by Format and its subclasses to keep track of the current positi...
C++ API: Locale ID object.
A UParseError struct is used to returned detailed information about parsing errors.
Basic definitions for ICU, for both C and C++ APIs.
UnicodeString is a string class that stores Unicode characters directly and provides similar function...
C++ API: MessagePattern class: Parses and represents ICU MessageFormat patterns.
UMessagePatternApostropheMode
Mode for when an apostrophe starts quoted literal text for MessageFormat output.
int8_t UBool
The ICU boolean type, a signed-byte integer.
A Locale object represents a specific geographical, political, or cultural region.