// © 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__