| // © 2016 and later: Unicode, Inc. and others. |
| // License & terms of use: http://www.unicode.org/copyright.html |
| /* |
| ******************************************************************************* |
| * Copyright (C) 2015, International Business Machines Corporation |
| * and others. All Rights Reserved. |
| ******************************************************************************* |
| * standardplural.h |
| * |
| * created on: 2015dec14 |
| * created by: Markus W. Scherer |
| */ |
| |
| #ifndef __STANDARDPLURAL_H__ |
| #define __STANDARDPLURAL_H__ |
| |
| #include "unicode/utypes.h" |
| |
| #if !UCONFIG_NO_FORMATTING |
| |
| U_NAMESPACE_BEGIN |
| |
| class UnicodeString; |
| |
| /** |
| * Standard CLDR plural form/category constants. |
| * See http://www.unicode.org/reports/tr35/tr35-numbers.html#Language_Plural_Rules |
| */ |
| class U_I18N_API StandardPlural { |
| public: |
| enum Form { |
| ZERO, |
| ONE, |
| TWO, |
| FEW, |
| MANY, |
| OTHER, |
| COUNT |
| }; |
| |
| /** |
| * @return the lowercase CLDR keyword string for the plural form |
| */ |
| static const char *getKeyword(Form p); |
| |
| /** |
| * @param keyword for example "few" or "other" |
| * @return the plural form corresponding to the keyword, or OTHER |
| */ |
| static Form orOtherFromString(const char *keyword) { |
| return static_cast<Form>(indexOrOtherIndexFromString(keyword)); |
| } |
| |
| /** |
| * @param keyword for example "few" or "other" |
| * @return the plural form corresponding to the keyword, or OTHER |
| */ |
| static Form orOtherFromString(const UnicodeString &keyword) { |
| return static_cast<Form>(indexOrOtherIndexFromString(keyword)); |
| } |
| |
| /** |
| * Sets U_ILLEGAL_ARGUMENT_ERROR if the keyword is not a plural form. |
| * |
| * @param keyword for example "few" or "other" |
| * @return the plural form corresponding to the keyword |
| */ |
| static Form fromString(const char *keyword, UErrorCode &errorCode) { |
| return static_cast<Form>(indexFromString(keyword, errorCode)); |
| } |
| |
| /** |
| * Sets U_ILLEGAL_ARGUMENT_ERROR if the keyword is not a plural form. |
| * |
| * @param keyword for example "few" or "other" |
| * @return the plural form corresponding to the keyword |
| */ |
| static Form fromString(const UnicodeString &keyword, UErrorCode &errorCode) { |
| return static_cast<Form>(indexFromString(keyword, errorCode)); |
| } |
| |
| /** |
| * @param keyword for example "few" or "other" |
| * @return the index of the plural form corresponding to the keyword, or a negative value |
| */ |
| static int32_t indexOrNegativeFromString(const char *keyword); |
| |
| /** |
| * @param keyword for example "few" or "other" |
| * @return the index of the plural form corresponding to the keyword, or a negative value |
| */ |
| static int32_t indexOrNegativeFromString(const UnicodeString &keyword); |
| |
| /** |
| * @param keyword for example "few" or "other" |
| * @return the index of the plural form corresponding to the keyword, or OTHER |
| */ |
| static int32_t indexOrOtherIndexFromString(const char *keyword) { |
| int32_t i = indexOrNegativeFromString(keyword); |
| return i >= 0 ? i : OTHER; |
| } |
| |
| /** |
| * @param keyword for example "few" or "other" |
| * @return the index of the plural form corresponding to the keyword, or OTHER |
| */ |
| static int32_t indexOrOtherIndexFromString(const UnicodeString &keyword) { |
| int32_t i = indexOrNegativeFromString(keyword); |
| return i >= 0 ? i : OTHER; |
| } |
| |
| /** |
| * Sets U_ILLEGAL_ARGUMENT_ERROR if the keyword is not a plural form. |
| * |
| * @param keyword for example "few" or "other" |
| * @return the index of the plural form corresponding to the keyword |
| */ |
| static int32_t indexFromString(const char *keyword, UErrorCode &errorCode); |
| |
| /** |
| * Sets U_ILLEGAL_ARGUMENT_ERROR if the keyword is not a plural form. |
| * |
| * @param keyword for example "few" or "other" |
| * @return the index of the plural form corresponding to the keyword |
| */ |
| static int32_t indexFromString(const UnicodeString &keyword, UErrorCode &errorCode); |
| }; |
| |
| U_NAMESPACE_END |
| |
| #endif // !UCONFIG_NO_FORMATTING |
| #endif // __STANDARDPLURAL_H__ |