1 // Copyright (C) 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4  *******************************************************************************
5  * Copyright (C) 2009-2015, International Business Machines Corporation and         *
6  * others. All Rights Reserved.                                                *
7  *******************************************************************************
8  */
9 #ifndef CURRPINF_H
10 #define CURRPINF_H
11 
12 #include "unicode/utypes.h"
13 
14 /**
15  * \file
16  * \brief C++ API: Currency Plural Information used by Decimal Format
17  */
18 
19 #if !UCONFIG_NO_FORMATTING
20 
21 #include "unicode/unistr.h"
22 
23 U_NAMESPACE_BEGIN
24 
25 class Locale;
26 class PluralRules;
27 class Hashtable;
28 
29 /**
30  * This class represents the information needed by
31  * DecimalFormat to format currency plural,
32  * such as "3.00 US dollars" or "1.00 US dollar".
33  * DecimalFormat creates for itself an instance of
34  * CurrencyPluralInfo from its locale data.
35  * If you need to change any of these symbols, you can get the
36  * CurrencyPluralInfo object from your
37  * DecimalFormat and modify it.
38  *
39  * Following are the information needed for currency plural format and parse:
40  * locale information,
41  * plural rule of the locale,
42  * currency plural pattern of the locale.
43  *
44  * @stable ICU 4.2
45  */
46 class  U_I18N_API CurrencyPluralInfo : public UObject {
47 public:
48 
49     /**
50      * Create a CurrencyPluralInfo object for the default locale.
51      * @param status output param set to success/failure code on exit
52      * @stable ICU 4.2
53      */
54     CurrencyPluralInfo(UErrorCode& status);
55 
56     /**
57      * Create a CurrencyPluralInfo object for the given locale.
58      * @param locale the locale
59      * @param status output param set to success/failure code on exit
60      * @stable ICU 4.2
61      */
62     CurrencyPluralInfo(const Locale& locale, UErrorCode& status);
63 
64     /**
65      * Copy constructor
66      *
67      * @stable ICU 4.2
68      */
69     CurrencyPluralInfo(const CurrencyPluralInfo& info);
70 
71 
72     /**
73      * Assignment operator
74      *
75      * @stable ICU 4.2
76      */
77     CurrencyPluralInfo& operator=(const CurrencyPluralInfo& info);
78 
79 
80     /**
81      * Destructor
82      *
83      * @stable ICU 4.2
84      */
85     virtual ~CurrencyPluralInfo();
86 
87 
88     /**
89      * Equal operator.
90      *
91      * @stable ICU 4.2
92      */
93     UBool operator==(const CurrencyPluralInfo& info) const;
94 
95 
96     /**
97      * Not equal operator
98      *
99      * @stable ICU 4.2
100      */
101     UBool operator!=(const CurrencyPluralInfo& info) const;
102 
103 
104     /**
105      * Clone
106      *
107      * @stable ICU 4.2
108      */
109     CurrencyPluralInfo* clone() const;
110 
111 
112     /**
113      * Gets plural rules of this locale, used for currency plural format
114      *
115      * @return plural rule
116      * @stable ICU 4.2
117      */
118     const PluralRules* getPluralRules() const;
119 
120     /**
121      * Given a plural count, gets currency plural pattern of this locale,
122      * used for currency plural format
123      *
124      * @param  pluralCount currency plural count
125      * @param  result      output param to receive the pattern
126      * @return a currency plural pattern based on plural count
127      * @stable ICU 4.2
128      */
129     UnicodeString& getCurrencyPluralPattern(const UnicodeString& pluralCount,
130                                             UnicodeString& result) const;
131 
132     /**
133      * Get locale
134      *
135      * @return locale
136      * @stable ICU 4.2
137      */
138     const Locale& getLocale() const;
139 
140     /**
141      * Set plural rules.
142      * The plural rule is set when CurrencyPluralInfo
143      * instance is created.
144      * You can call this method to reset plural rules only if you want
145      * to modify the default plural rule of the locale.
146      *
147      * @param ruleDescription new plural rule description
148      * @param status output param set to success/failure code on exit
149      * @stable ICU 4.2
150      */
151     void setPluralRules(const UnicodeString& ruleDescription,
152                         UErrorCode& status);
153 
154     /**
155      * Set currency plural pattern.
156      * The currency plural pattern is set when CurrencyPluralInfo
157      * instance is created.
158      * You can call this method to reset currency plural pattern only if
159      * you want to modify the default currency plural pattern of the locale.
160      *
161      * @param pluralCount the plural count for which the currency pattern will
162      *                    be overridden.
163      * @param pattern     the new currency plural pattern
164      * @param status      output param set to success/failure code on exit
165      * @stable ICU 4.2
166      */
167     void setCurrencyPluralPattern(const UnicodeString& pluralCount,
168                                   const UnicodeString& pattern,
169                                   UErrorCode& status);
170 
171     /**
172      * Set locale
173      *
174      * @param loc     the new locale to set
175      * @param status  output param set to success/failure code on exit
176      * @stable ICU 4.2
177      */
178     void setLocale(const Locale& loc, UErrorCode& status);
179 
180     /**
181      * ICU "poor man's RTTI", returns a UClassID for the actual class.
182      *
183      * @stable ICU 4.2
184      */
185     virtual UClassID getDynamicClassID() const;
186 
187     /**
188      * ICU "poor man's RTTI", returns a UClassID for this class.
189      *
190      * @stable ICU 4.2
191      */
192     static UClassID U_EXPORT2 getStaticClassID();
193 
194 private:
195     friend class DecimalFormat;
196     friend class DecimalFormatImpl;
197 
198     void initialize(const Locale& loc, UErrorCode& status);
199 
200     void setupCurrencyPluralPattern(const Locale& loc, UErrorCode& status);
201 
202     /*
203      * delete hash table
204      *
205      * @param hTable  hash table to be deleted
206      */
207     void deleteHash(Hashtable* hTable);
208 
209 
210     /*
211      * initialize hash table
212      *
213      * @param status   output param set to success/failure code on exit
214      * @return         hash table initialized
215      */
216     Hashtable* initHash(UErrorCode& status);
217 
218 
219 
220     /**
221      * copy hash table
222      *
223      * @param source   the source to copy from
224      * @param target   the target to copy to
225      * @param status   error code
226      */
227     void copyHash(const Hashtable* source, Hashtable* target, UErrorCode& status);
228 
229     //-------------------- private data member ---------------------
230     // map from plural count to currency plural pattern, for example
231     // a plural pattern defined in "CurrencyUnitPatterns" is
232     // "one{{0} {1}}", in which "one" is a plural count
233     // and "{0} {1}" is a currency plural pattern".
234     // The currency plural pattern saved in this mapping is the pattern
235     // defined in "CurrencyUnitPattern" by replacing
236     // {0} with the number format pattern,
237     // and {1} with 3 currency sign.
238     Hashtable* fPluralCountToCurrencyUnitPattern;
239 
240     /*
241      * The plural rule is used to format currency plural name,
242      * for example: "3.00 US Dollars".
243      * If there are 3 currency signs in the currency patttern,
244      * the 3 currency signs will be replaced by currency plural name.
245      */
246     PluralRules* fPluralRules;
247 
248     // locale
249     Locale* fLocale;
250 };
251 
252 
253 inline UBool
254 CurrencyPluralInfo::operator!=(const CurrencyPluralInfo& info) const {              return !operator==(info);                                                   }
255 
256 U_NAMESPACE_END
257 
258 #endif /* #if !UCONFIG_NO_FORMATTING */
259 
260 #endif // _CURRPINFO
261 //eof
262