]> git.saurik.com Git - apple/icu.git/blame - icuSources/test/intltest/numberformattesttuple.h
ICU-62123.0.1.tar.gz
[apple/icu.git] / icuSources / test / intltest / numberformattesttuple.h
CommitLineData
f3c0d7a5
A
1// © 2016 and later: Unicode, Inc. and others.
2// License & terms of use: http://www.unicode.org/copyright.html
2ca993e8
A
3/*
4*******************************************************************************
5* Copyright (C) 2015, International Business Machines Corporation and *
6* others. All Rights Reserved. *
7*******************************************************************************
8*/
9#ifndef _NUMBER_FORMAT_TEST_TUPLE
10#define _NUMBER_FORMAT_TEST_TUPLE
11
12#include "unicode/utypes.h"
13
14#if !UCONFIG_NO_FORMATTING
15
2ca993e8
A
16#include "unicode/decimfmt.h"
17#include "unicode/ucurr.h"
18
19#define NFTT_GET_FIELD(tuple, fieldName, defaultValue) ((tuple).fieldName##Flag ? (tuple).fieldName : (defaultValue))
20
21U_NAMESPACE_USE
22
23enum ENumberFormatTestTupleField {
24 kLocale,
25 kCurrency,
26 kPattern,
27 kFormat,
28 kOutput,
29 kComment,
30 kMinIntegerDigits,
31 kMaxIntegerDigits,
32 kMinFractionDigits,
33 kMaxFractionDigits,
34 kMinGroupingDigits,
35 kBreaks,
36 kUseSigDigits,
37 kMinSigDigits,
38 kMaxSigDigits,
39 kUseGrouping,
40 kMultiplier,
41 kRoundingIncrement,
42 kFormatWidth,
43 kPadCharacter,
44 kUseScientific,
45 kGrouping,
46 kGrouping2,
47 kRoundingMode,
48 kCurrencyUsage,
49 kMinimumExponentDigits,
50 kExponentSignAlwaysShown,
51 kDecimalSeparatorAlwaysShown,
52 kPadPosition,
53 kPositivePrefix,
54 kPositiveSuffix,
55 kNegativePrefix,
56 kNegativeSuffix,
0f5d89e8 57 kSignAlwaysShown,
2ca993e8
A
58 kLocalizedPattern,
59 kToPattern,
60 kToLocalizedPattern,
61 kStyle,
62 kParse,
63 kLenient,
64 kPlural,
65 kParseIntegerOnly,
66 kDecimalPatternMatchRequired,
0f5d89e8 67 kParseCaseSensitive,
2ca993e8
A
68 kParseNoExponent,
69 kOutputCurrency,
70 kNumberFormatTestTupleFieldCount
71};
72
73/**
74 * NumberFormatTestTuple represents the data for a single data driven test.
75 * It consist of named fields each of which may or may not be set. Each field
76 * has a particular meaning in the test. For more information on what each
77 * field means and how the data drive tests work, please see
78 * https://docs.google.com/document/d/1T2P0p953_Lh1pRwo-5CuPVrHlIBa_wcXElG-Hhg_WHM/edit?usp=sharing
79 * Each field is optional. That is, a certain field may be unset for a given
80 * test. The UBool fields ending in "Flag" indicate whether the corrresponding
81 * field is set or not. TRUE means set; FALSE means unset. An unset field
82 * generally means that the corresponding setter method is not called on
83 * the NumberFormat object.
84 */
85
86class NumberFormatTestTuple {
87public:
88 Locale locale;
89 UnicodeString currency;
90 UnicodeString pattern;
91 UnicodeString format;
92 UnicodeString output;
93 UnicodeString comment;
94 int32_t minIntegerDigits;
95 int32_t maxIntegerDigits;
96 int32_t minFractionDigits;
97 int32_t maxFractionDigits;
98 int32_t minGroupingDigits;
99 UnicodeString breaks;
100 int32_t useSigDigits;
101 int32_t minSigDigits;
102 int32_t maxSigDigits;
103 int32_t useGrouping;
104 int32_t multiplier;
105 double roundingIncrement;
106 int32_t formatWidth;
107 UnicodeString padCharacter;
108 int32_t useScientific;
109 int32_t grouping;
110 int32_t grouping2;
111 DecimalFormat::ERoundingMode roundingMode;
112 UCurrencyUsage currencyUsage;
113 int32_t minimumExponentDigits;
114 int32_t exponentSignAlwaysShown;
115 int32_t decimalSeparatorAlwaysShown;
116 DecimalFormat::EPadPosition padPosition;
117 UnicodeString positivePrefix;
118 UnicodeString positiveSuffix;
119 UnicodeString negativePrefix;
120 UnicodeString negativeSuffix;
0f5d89e8 121 int32_t signAlwaysShown;
2ca993e8
A
122 UnicodeString localizedPattern;
123 UnicodeString toPattern;
124 UnicodeString toLocalizedPattern;
125 UNumberFormatStyle style;
126 UnicodeString parse;
127 int32_t lenient;
128 UnicodeString plural;
129 int32_t parseIntegerOnly;
130 int32_t decimalPatternMatchRequired;
131 int32_t parseNoExponent;
0f5d89e8 132 int32_t parseCaseSensitive;
2ca993e8
A
133 UnicodeString outputCurrency;
134
135 UBool localeFlag;
136 UBool currencyFlag;
137 UBool patternFlag;
138 UBool formatFlag;
139 UBool outputFlag;
140 UBool commentFlag;
141 UBool minIntegerDigitsFlag;
142 UBool maxIntegerDigitsFlag;
143 UBool minFractionDigitsFlag;
144 UBool maxFractionDigitsFlag;
145 UBool minGroupingDigitsFlag;
146 UBool breaksFlag;
147 UBool useSigDigitsFlag;
148 UBool minSigDigitsFlag;
149 UBool maxSigDigitsFlag;
150 UBool useGroupingFlag;
151 UBool multiplierFlag;
152 UBool roundingIncrementFlag;
153 UBool formatWidthFlag;
154 UBool padCharacterFlag;
155 UBool useScientificFlag;
156 UBool groupingFlag;
157 UBool grouping2Flag;
158 UBool roundingModeFlag;
159 UBool currencyUsageFlag;
160 UBool minimumExponentDigitsFlag;
161 UBool exponentSignAlwaysShownFlag;
162 UBool decimalSeparatorAlwaysShownFlag;
163 UBool padPositionFlag;
164 UBool positivePrefixFlag;
165 UBool positiveSuffixFlag;
166 UBool negativePrefixFlag;
167 UBool negativeSuffixFlag;
0f5d89e8 168 UBool signAlwaysShownFlag;
2ca993e8
A
169 UBool localizedPatternFlag;
170 UBool toPatternFlag;
171 UBool toLocalizedPatternFlag;
172 UBool styleFlag;
173 UBool parseFlag;
174 UBool lenientFlag;
175 UBool pluralFlag;
176 UBool parseIntegerOnlyFlag;
177 UBool decimalPatternMatchRequiredFlag;
178 UBool parseNoExponentFlag;
0f5d89e8 179 UBool parseCaseSensitiveFlag;
2ca993e8
A
180 UBool outputCurrencyFlag;
181
182 NumberFormatTestTuple() {
183 clear();
184 }
185
186 /**
187 * Sets a particular field using the string representation of that field.
188 * @param field the field to set.
189 * @param fieldValue the string representation of the field value.
190 * @param status error returned here such as when the string representation
191 * of the field value cannot be parsed.
192 * @return TRUE on success or FALSE if an error was set in status.
193 */
194 UBool setField(
195 ENumberFormatTestTupleField field,
196 const UnicodeString &fieldValue,
197 UErrorCode &status);
198 /**
199 * Clears a particular field.
200 * @param field the field to clear.
201 * @param status error set here.
202 * @return TRUE on success or FALSE if error was set.
203 */
204 UBool clearField(
205 ENumberFormatTestTupleField field,
206 UErrorCode &status);
207 /**
208 * Clears every field.
209 */
210 void clear();
211
212 /**
213 * Returns the string representation of the test case this object
214 * currently represents.
215 * @param appendTo the result appended here.
216 * @return appendTo
217 */
218 UnicodeString &toString(UnicodeString &appendTo) const;
219
220 /**
221 * Converts the name of a field to the corresponding enum value.
222 * @param name the name of the field as a string.
223 * @return the corresponding enum value or kNumberFormatTestFieldCount
224 * if name does not map to any recognized field name.
225 */
226 static ENumberFormatTestTupleField getFieldByName(const UnicodeString &name);
227private:
228 const void *getFieldAddress(int32_t fieldId) const;
229 void *getMutableFieldAddress(int32_t fieldId);
230 void setFlag(int32_t fieldId, UBool value);
231 UBool isFlag(int32_t fieldId) const;
232};
233
234#endif /* !UCONFIG_NO_FORMATTING */
235#endif