1*0e209d39SAndroid Build Coastguard Worker // © 2016 and later: Unicode, Inc. and others. 2*0e209d39SAndroid Build Coastguard Worker // License & terms of use: http://www.unicode.org/copyright.html 3*0e209d39SAndroid Build Coastguard Worker /* 4*0e209d39SAndroid Build Coastguard Worker ***************************************************************************************** 5*0e209d39SAndroid Build Coastguard Worker * Copyright (C) 2010-2013, International Business Machines 6*0e209d39SAndroid Build Coastguard Worker * Corporation and others. All Rights Reserved. 7*0e209d39SAndroid Build Coastguard Worker ***************************************************************************************** 8*0e209d39SAndroid Build Coastguard Worker */ 9*0e209d39SAndroid Build Coastguard Worker 10*0e209d39SAndroid Build Coastguard Worker #ifndef UGENDER_H 11*0e209d39SAndroid Build Coastguard Worker #define UGENDER_H 12*0e209d39SAndroid Build Coastguard Worker 13*0e209d39SAndroid Build Coastguard Worker #include "unicode/utypes.h" 14*0e209d39SAndroid Build Coastguard Worker 15*0e209d39SAndroid Build Coastguard Worker #if !UCONFIG_NO_FORMATTING 16*0e209d39SAndroid Build Coastguard Worker 17*0e209d39SAndroid Build Coastguard Worker #if U_SHOW_CPLUSPLUS_API 18*0e209d39SAndroid Build Coastguard Worker #include "unicode/localpointer.h" 19*0e209d39SAndroid Build Coastguard Worker #endif // U_SHOW_CPLUSPLUS_API 20*0e209d39SAndroid Build Coastguard Worker 21*0e209d39SAndroid Build Coastguard Worker /** 22*0e209d39SAndroid Build Coastguard Worker * \file 23*0e209d39SAndroid Build Coastguard Worker * \brief C API: The purpose of this API is to compute the gender of a list as a 24*0e209d39SAndroid Build Coastguard Worker * whole given the gender of each element. 25*0e209d39SAndroid Build Coastguard Worker * 26*0e209d39SAndroid Build Coastguard Worker */ 27*0e209d39SAndroid Build Coastguard Worker 28*0e209d39SAndroid Build Coastguard Worker /** 29*0e209d39SAndroid Build Coastguard Worker * Genders 30*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 31*0e209d39SAndroid Build Coastguard Worker */ 32*0e209d39SAndroid Build Coastguard Worker enum UGender { 33*0e209d39SAndroid Build Coastguard Worker /** 34*0e209d39SAndroid Build Coastguard Worker * Male gender. 35*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 36*0e209d39SAndroid Build Coastguard Worker */ 37*0e209d39SAndroid Build Coastguard Worker UGENDER_MALE, 38*0e209d39SAndroid Build Coastguard Worker /** 39*0e209d39SAndroid Build Coastguard Worker * Female gender. 40*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 41*0e209d39SAndroid Build Coastguard Worker */ 42*0e209d39SAndroid Build Coastguard Worker UGENDER_FEMALE, 43*0e209d39SAndroid Build Coastguard Worker /** 44*0e209d39SAndroid Build Coastguard Worker * Neutral gender. 45*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 46*0e209d39SAndroid Build Coastguard Worker */ 47*0e209d39SAndroid Build Coastguard Worker UGENDER_OTHER 48*0e209d39SAndroid Build Coastguard Worker }; 49*0e209d39SAndroid Build Coastguard Worker /** 50*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 51*0e209d39SAndroid Build Coastguard Worker */ 52*0e209d39SAndroid Build Coastguard Worker typedef enum UGender UGender; 53*0e209d39SAndroid Build Coastguard Worker 54*0e209d39SAndroid Build Coastguard Worker struct UGenderInfo; 55*0e209d39SAndroid Build Coastguard Worker /** 56*0e209d39SAndroid Build Coastguard Worker * Opaque UGenderInfo object for use in C programs. 57*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 58*0e209d39SAndroid Build Coastguard Worker */ 59*0e209d39SAndroid Build Coastguard Worker typedef struct UGenderInfo UGenderInfo; 60*0e209d39SAndroid Build Coastguard Worker 61*0e209d39SAndroid Build Coastguard Worker /** 62*0e209d39SAndroid Build Coastguard Worker * Opens a new UGenderInfo object given locale. 63*0e209d39SAndroid Build Coastguard Worker * @param locale The locale for which the rules are desired. 64*0e209d39SAndroid Build Coastguard Worker * @param status UErrorCode pointer 65*0e209d39SAndroid Build Coastguard Worker * @return A UGenderInfo for the specified locale, or NULL if an error occurred. 66*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 67*0e209d39SAndroid Build Coastguard Worker */ 68*0e209d39SAndroid Build Coastguard Worker U_CAPI const UGenderInfo* U_EXPORT2 69*0e209d39SAndroid Build Coastguard Worker ugender_getInstance(const char *locale, UErrorCode *status); 70*0e209d39SAndroid Build Coastguard Worker 71*0e209d39SAndroid Build Coastguard Worker 72*0e209d39SAndroid Build Coastguard Worker /** 73*0e209d39SAndroid Build Coastguard Worker * Given a list, returns the gender of the list as a whole. 74*0e209d39SAndroid Build Coastguard Worker * @param genderInfo pointer that ugender_getInstance returns. 75*0e209d39SAndroid Build Coastguard Worker * @param genders the gender of each element in the list. 76*0e209d39SAndroid Build Coastguard Worker * @param size the size of the list. 77*0e209d39SAndroid Build Coastguard Worker * @param status A pointer to a UErrorCode to receive any errors. 78*0e209d39SAndroid Build Coastguard Worker * @return The gender of the list. 79*0e209d39SAndroid Build Coastguard Worker * @stable ICU 50 80*0e209d39SAndroid Build Coastguard Worker */ 81*0e209d39SAndroid Build Coastguard Worker U_CAPI UGender U_EXPORT2 82*0e209d39SAndroid Build Coastguard Worker ugender_getListGender(const UGenderInfo* genderInfo, const UGender *genders, int32_t size, UErrorCode *status); 83*0e209d39SAndroid Build Coastguard Worker 84*0e209d39SAndroid Build Coastguard Worker #endif /* #if !UCONFIG_NO_FORMATTING */ 85*0e209d39SAndroid Build Coastguard Worker 86*0e209d39SAndroid Build Coastguard Worker #endif 87