1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
4 *******************************************************************************
5 * Copyright (C) 2008-2013, International Business Machines Corporation and
6 * others. All Rights Reserved.
7 *******************************************************************************
12 * Modification History:*
13 * Date Name Description
15 ********************************************************************************
23 * \brief C++ API: GenderInfo computes the gender of a list.
26 #include "unicode/utypes.h"
28 #if U_SHOW_CPLUSPLUS_API
30 #if !UCONFIG_NO_FORMATTING
32 #include "unicode/locid.h"
33 #include "unicode/ugender.h"
34 #include "unicode/uobject.h"
40 /** \internal Forward Declaration */
41 void U_CALLCONV GenderInfo_initCache(UErrorCode &status);
44 * GenderInfo computes the gender of a list as a whole given the gender of
48 class U_I18N_API GenderInfo : public UObject {
52 * Provides access to the predefined GenderInfo object for a given
55 * @param locale The locale for which a <code>GenderInfo</code> object is
57 * @param status Output param set to success/failure code on exit, which
58 * must not indicate a failure before the function call.
59 * @return The predefined <code>GenderInfo</code> object pointer for
60 * this locale. The returned object is immutable, so it is
61 * declared as const. Caller does not own the returned
62 * pointer, so it must not attempt to free it.
65 static const GenderInfo* U_EXPORT2 getInstance(const Locale& locale, UErrorCode& status);
68 * Determines the gender of a list as a whole given the gender of each
71 * @param genders the gender of each element in the list.
72 * @param length the length of gender array.
73 * @param status Output param set to success/failure code on exit, which
74 * must not indicate a failure before the function call.
75 * @return the gender of the whole list.
78 UGender getListGender(const UGender* genders, int32_t length, UErrorCode& status) const;
85 virtual ~GenderInfo();
91 * Copy constructor. One object per locale invariant. Clients
92 * must never copy GenderInfo objects.
94 GenderInfo(const GenderInfo& other);
97 * Assignment operator. Not applicable to immutable objects.
99 GenderInfo& operator=(const GenderInfo&);
103 static const GenderInfo* getNeutralInstance();
105 static const GenderInfo* getMixedNeutralInstance();
107 static const GenderInfo* getMaleTaintsInstance();
109 static const GenderInfo* loadInstance(const Locale& locale, UErrorCode& status);
111 friend class ::GenderInfoTest;
112 friend void U_CALLCONV GenderInfo_initCache(UErrorCode &status);
117 #endif /* #if !UCONFIG_NO_FORMATTING */
119 #endif /* U_SHOW_CPLUSPLUS_API */