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) 2015, International Business Machines
6 * Corporation and others. All Rights Reserved.
7 *******************************************************************************
8 * digitaffixesandpadding.h
9 *
10 * created on: 2015jan06
11 * created by: Travis Keep
12 */
13
14 #ifndef __DIGITAFFIXESANDPADDING_H__
15 #define __DIGITAFFIXESANDPADDING_H__
16
17 #include "unicode/utypes.h"
18
19 #if !UCONFIG_NO_FORMATTING
20
21 #include "unicode/uobject.h"
22 #include "pluralaffix.h"
23
24 U_NAMESPACE_BEGIN
25
26 class DigitList;
27 class ValueFormatter;
28 class UnicodeString;
29 class FieldPositionHandler;
30 class PluralRules;
31 class VisibleDigitsWithExponent;
32
33 /**
34 * A formatter of numbers. This class can format any numerical value
35 * except for not a number (NaN), positive infinity, and negative infinity.
36 * This class manages prefixes, suffixes, and padding but delegates the
37 * formatting of actual positive values to a ValueFormatter.
38 */
39 class U_I18N_API DigitAffixesAndPadding : public UMemory {
40 public:
41
42 /**
43 * Equivalent to DecimalFormat EPadPosition, but redeclared here to prevent
44 * depending on DecimalFormat which would cause a circular dependency.
45 */
46 enum EPadPosition {
47 kPadBeforePrefix,
48 kPadAfterPrefix,
49 kPadBeforeSuffix,
50 kPadAfterSuffix
51 };
52
53 /**
54 * The positive prefix
55 */
56 PluralAffix fPositivePrefix;
57
58 /**
59 * The positive suffix
60 */
61 PluralAffix fPositiveSuffix;
62
63 /**
64 * The negative suffix
65 */
66 PluralAffix fNegativePrefix;
67
68 /**
69 * The negative suffix
70 */
71 PluralAffix fNegativeSuffix;
72
73 /**
74 * The padding position
75 */
76 EPadPosition fPadPosition;
77
78 /**
79 * The padding character.
80 */
81 UChar32 fPadChar;
82
83 /**
84 * The field width in code points. The format method inserts instances of
85 * the padding character as needed in the desired padding position so that
86 * the entire formatted string contains this many code points. If the
87 * formatted string already exceeds this many code points, the format method
88 * inserts no padding.
89 */
90 int32_t fWidth;
91
92 /**
93 * Pad position is before prefix; padding character is '*' field width is 0.
94 * The affixes are all the empty string with no annotated fields with just
95 * the 'other' plural variation.
96 */
DigitAffixesAndPadding()97 DigitAffixesAndPadding()
98 : fPadPosition(kPadBeforePrefix), fPadChar(0x2a), fWidth(0) { }
99
100 /**
101 * Returns TRUE if this object is equal to rhs.
102 */
equals(const DigitAffixesAndPadding & rhs)103 UBool equals(const DigitAffixesAndPadding &rhs) const {
104 return (fPositivePrefix.equals(rhs.fPositivePrefix) &&
105 fPositiveSuffix.equals(rhs.fPositiveSuffix) &&
106 fNegativePrefix.equals(rhs.fNegativePrefix) &&
107 fNegativeSuffix.equals(rhs.fNegativeSuffix) &&
108 fPadPosition == rhs.fPadPosition &&
109 fWidth == rhs.fWidth &&
110 fPadChar == rhs.fPadChar);
111 }
112
113 /**
114 * Returns TRUE if a plural rules instance is needed to complete the
115 * formatting by detecting if any of the affixes have multiple plural
116 * variations.
117 */
118 UBool needsPluralRules() const;
119
120 /**
121 * Formats value and appends to appendTo.
122 *
123 * @param value the value to format. May be NaN or ininite.
124 * @param formatter handles the details of formatting the actual value.
125 * @param handler records field positions
126 * @param optPluralRules the plural rules, but may be NULL if
127 * needsPluralRules returns FALSE.
128 * @appendTo formatted string appended here.
129 * @status any error returned here.
130 */
131 UnicodeString &format(
132 const VisibleDigitsWithExponent &value,
133 const ValueFormatter &formatter,
134 FieldPositionHandler &handler,
135 const PluralRules *optPluralRules,
136 UnicodeString &appendTo,
137 UErrorCode &status) const;
138
139 /**
140 * For testing only.
141 */
142 UnicodeString &format(
143 DigitList &value,
144 const ValueFormatter &formatter,
145 FieldPositionHandler &handler,
146 const PluralRules *optPluralRules,
147 UnicodeString &appendTo,
148 UErrorCode &status) const;
149
150 /**
151 * Formats a 32-bit integer and appends to appendTo. When formatting an
152 * integer, this method is preferred to plain format as it can run
153 * several times faster under certain conditions.
154 *
155 * @param value the value to format.
156 * @param formatter handles the details of formatting the actual value.
157 * @param handler records field positions
158 * @param optPluralRules the plural rules, but may be NULL if
159 * needsPluralRules returns FALSE.
160 * @appendTo formatted string appended here.
161 * @status any error returned here.
162 */
163 UnicodeString &formatInt32(
164 int32_t value,
165 const ValueFormatter &formatter,
166 FieldPositionHandler &handler,
167 const PluralRules *optPluralRules,
168 UnicodeString &appendTo,
169 UErrorCode &status) const;
170
171 private:
172 UnicodeString &appendPadding(int32_t paddingCount, UnicodeString &appendTo) const;
173
174 };
175
176
177 U_NAMESPACE_END
178 #endif /* #if !UCONFIG_NO_FORMATTING */
179 #endif // __DIGITAFFIXANDPADDING_H__
180