]> git.saurik.com Git - apple/icu.git/blame - icuSources/i18n/unicode/unumberformatter.h
ICU-64260.0.1.tar.gz
[apple/icu.git] / icuSources / i18n / unicode / unumberformatter.h
CommitLineData
0f5d89e8
A
1// © 2018 and later: Unicode, Inc. and others.
2// License & terms of use: http://www.unicode.org/copyright.html
3
4#include "unicode/utypes.h"
5
6#if !UCONFIG_NO_FORMATTING
7#ifndef __UNUMBERFORMATTER_H__
8#define __UNUMBERFORMATTER_H__
9
3d1f044b 10#include "unicode/parseerr.h"
0f5d89e8
A
11#include "unicode/ufieldpositer.h"
12#include "unicode/umisc.h"
3d1f044b 13#include "unicode/uformattedvalue.h"
0f5d89e8
A
14
15
16/**
17 * \file
18 * \brief C-compatible API for localized number formatting; not recommended for C++.
19 *
20 * This is the C-compatible version of the NumberFormatter API introduced in ICU 60. C++ users should
21 * include unicode/numberformatter.h and use the proper C++ APIs.
22 *
23 * The C API accepts a number skeleton string for specifying the settings for formatting, which covers a
24 * very large subset of all possible number formatting features. For more information on number skeleton
25 * strings, see unicode/numberformatter.h.
26 *
27 * When using UNumberFormatter, which is treated as immutable, the results are exported to a mutable
28 * UFormattedNumber object, which you subsequently use for populating your string buffer or iterating over
29 * the fields.
30 *
31 * Example code:
32 * <pre>
33 * // Setup:
34 * UErrorCode ec = U_ZERO_ERROR;
35 * UNumberFormatter* uformatter = unumf_openForSkeletonAndLocale(u"precision-integer", -1, "en", &ec);
36 * UFormattedNumber* uresult = unumf_openResult(&ec);
37 * if (U_FAILURE(ec)) { return; }
38 *
39 * // Format a double:
40 * unumf_formatDouble(uformatter, 5142.3, uresult, &ec);
41 * if (U_FAILURE(ec)) { return; }
42 *
43 * // Export the string to a malloc'd buffer:
44 * int32_t len = unumf_resultToString(uresult, NULL, 0, &ec);
45 * // at this point, ec == U_BUFFER_OVERFLOW_ERROR
46 * ec = U_ZERO_ERROR;
47 * UChar* buffer = (UChar*) malloc((len+1)*sizeof(UChar));
48 * unumf_resultToString(uresult, buffer, len+1, &ec);
49 * if (U_FAILURE(ec)) { return; }
50 * // buffer should equal "5,142"
51 *
52 * // Cleanup:
53 * unumf_close(uformatter);
54 * unumf_closeResult(uresult);
55 * free(buffer);
56 * </pre>
57 *
58 * If you are a C++ user linking against the C libraries, you can use the LocalPointer versions of these
59 * APIs. The following example uses LocalPointer with the decimal number and field position APIs:
60 *
61 * <pre>
62 * // Setup:
63 * LocalUNumberFormatterPointer uformatter(unumf_openForSkeletonAndLocale(u"percent", -1, "en", &ec));
64 * LocalUFormattedNumberPointer uresult(unumf_openResult(&ec));
65 * if (U_FAILURE(ec)) { return; }
66 *
67 * // Format a decimal number:
68 * unumf_formatDecimal(uformatter.getAlias(), "9.87E-3", -1, uresult.getAlias(), &ec);
69 * if (U_FAILURE(ec)) { return; }
70 *
71 * // Get the location of the percent sign:
72 * UFieldPosition ufpos = {UNUM_PERCENT_FIELD, 0, 0};
73 * unumf_resultNextFieldPosition(uresult.getAlias(), &ufpos, &ec);
74 * // ufpos should contain beginIndex=7 and endIndex=8 since the string is "0.00987%"
75 *
76 * // No need to do any cleanup since we are using LocalPointer.
77 * </pre>
78 */
79
80
81#ifndef U_HIDE_DRAFT_API
82/**
83 * An enum declaring how to render units, including currencies. Example outputs when formatting 123 USD and 123
84 * meters in <em>en-CA</em>:
85 *
86 * <p>
87 * <ul>
88 * <li>NARROW*: "$123.00" and "123 m"
89 * <li>SHORT: "US$ 123.00" and "123 m"
90 * <li>FULL_NAME: "123.00 US dollars" and "123 meters"
91 * <li>ISO_CODE: "USD 123.00" and undefined behavior
92 * <li>HIDDEN: "123.00" and "123"
93 * </ul>
94 *
95 * <p>
3d1f044b 96 * This enum is similar to {@link UMeasureFormatWidth}.
0f5d89e8
A
97 *
98 * @draft ICU 60
99 */
100typedef enum UNumberUnitWidth {
101 /**
102 * Print an abbreviated version of the unit name. Similar to SHORT, but always use the shortest available
103 * abbreviation or symbol. This option can be used when the context hints at the identity of the unit. For more
104 * information on the difference between NARROW and SHORT, see SHORT.
105 *
106 * <p>
107 * In CLDR, this option corresponds to the "Narrow" format for measure units and the "¤¤¤¤¤" placeholder for
108 * currencies.
109 *
110 * @draft ICU 60
111 */
112 UNUM_UNIT_WIDTH_NARROW,
113
114 /**
115 * Print an abbreviated version of the unit name. Similar to NARROW, but use a slightly wider abbreviation or
116 * symbol when there may be ambiguity. This is the default behavior.
117 *
118 * <p>
119 * For example, in <em>es-US</em>, the SHORT form for Fahrenheit is "{0} °F", but the NARROW form is "{0}°",
120 * since Fahrenheit is the customary unit for temperature in that locale.
121 *
122 * <p>
123 * In CLDR, this option corresponds to the "Short" format for measure units and the "¤" placeholder for
124 * currencies.
125 *
126 * @draft ICU 60
127 */
128 UNUM_UNIT_WIDTH_SHORT,
129
130 /**
131 * Print the full name of the unit, without any abbreviations.
132 *
133 * <p>
134 * In CLDR, this option corresponds to the default format for measure units and the "¤¤¤" placeholder for
135 * currencies.
136 *
137 * @draft ICU 60
138 */
139 UNUM_UNIT_WIDTH_FULL_NAME,
140
141 /**
142 * Use the three-digit ISO XXX code in place of the symbol for displaying currencies. The behavior of this
143 * option is currently undefined for use with measure units.
144 *
145 * <p>
146 * In CLDR, this option corresponds to the "¤¤" placeholder for currencies.
147 *
148 * @draft ICU 60
149 */
150 UNUM_UNIT_WIDTH_ISO_CODE,
151
152 /**
153 * Format the number according to the specified unit, but do not display the unit. For currencies, apply
154 * monetary symbols and formats as with SHORT, but omit the currency symbol. For measure units, the behavior is
155 * equivalent to not specifying the unit at all.
156 *
157 * @draft ICU 60
158 */
159 UNUM_UNIT_WIDTH_HIDDEN,
160
161 /**
162 * One more than the highest UNumberUnitWidth value.
163 *
164 * @internal ICU 60: The numeric value may change over time; see ICU ticket #12420.
165 */
166 UNUM_UNIT_WIDTH_COUNT
167} UNumberUnitWidth;
168#endif /* U_HIDE_DRAFT_API */
169
170#ifndef U_HIDE_DRAFT_API
171/**
172 * An enum declaring the strategy for when and how to display grouping separators (i.e., the
173 * separator, often a comma or period, after every 2-3 powers of ten). The choices are several
174 * pre-built strategies for different use cases that employ locale data whenever possible. Example
175 * outputs for 1234 and 1234567 in <em>en-IN</em>:
176 *
177 * <ul>
178 * <li>OFF: 1234 and 12345
179 * <li>MIN2: 1234 and 12,34,567
180 * <li>AUTO: 1,234 and 12,34,567
181 * <li>ON_ALIGNED: 1,234 and 12,34,567
182 * <li>THOUSANDS: 1,234 and 1,234,567
183 * </ul>
184 *
185 * <p>
186 * The default is AUTO, which displays grouping separators unless the locale data says that grouping
187 * is not customary. To force grouping for all numbers greater than 1000 consistently across locales,
188 * use ON_ALIGNED. On the other hand, to display grouping less frequently than the default, use MIN2
189 * or OFF. See the docs of each option for details.
190 *
191 * <p>
192 * Note: This enum specifies the strategy for grouping sizes. To set which character to use as the
193 * grouping separator, use the "symbols" setter.
194 *
3d1f044b 195 * @draft ICU 63
0f5d89e8 196 */
3d1f044b 197typedef enum UNumberGroupingStrategy {
0f5d89e8
A
198 /**
199 * Do not display grouping separators in any locale.
200 *
201 * @draft ICU 61
202 */
203 UNUM_GROUPING_OFF,
204
205 /**
206 * Display grouping using locale defaults, except do not show grouping on values smaller than
207 * 10000 (such that there is a <em>minimum of two digits</em> before the first separator).
208 *
209 * <p>
210 * Note that locales may restrict grouping separators to be displayed only on 1 million or
211 * greater (for example, ee and hu) or disable grouping altogether (for example, bg currency).
212 *
213 * <p>
214 * Locale data is used to determine whether to separate larger numbers into groups of 2
215 * (customary in South Asia) or groups of 3 (customary in Europe and the Americas).
216 *
217 * @draft ICU 61
218 */
219 UNUM_GROUPING_MIN2,
220
221 /**
222 * Display grouping using the default strategy for all locales. This is the default behavior.
223 *
224 * <p>
225 * Note that locales may restrict grouping separators to be displayed only on 1 million or
226 * greater (for example, ee and hu) or disable grouping altogether (for example, bg currency).
227 *
228 * <p>
229 * Locale data is used to determine whether to separate larger numbers into groups of 2
230 * (customary in South Asia) or groups of 3 (customary in Europe and the Americas).
231 *
232 * @draft ICU 61
233 */
234 UNUM_GROUPING_AUTO,
235
236 /**
237 * Always display the grouping separator on values of at least 1000.
238 *
239 * <p>
240 * This option ignores the locale data that restricts or disables grouping, described in MIN2 and
241 * AUTO. This option may be useful to normalize the alignment of numbers, such as in a
242 * spreadsheet.
243 *
244 * <p>
245 * Locale data is used to determine whether to separate larger numbers into groups of 2
246 * (customary in South Asia) or groups of 3 (customary in Europe and the Americas).
247 *
248 * @draft ICU 61
249 */
250 UNUM_GROUPING_ON_ALIGNED,
251
252 /**
253 * Use the Western defaults: groups of 3 and enabled for all numbers 1000 or greater. Do not use
254 * locale data for determining the grouping strategy.
255 *
256 * @draft ICU 61
257 */
3d1f044b 258 UNUM_GROUPING_THOUSANDS
0f5d89e8 259
3d1f044b
A
260#ifndef U_HIDE_INTERNAL_API
261 ,
0f5d89e8 262 /**
3d1f044b 263 * One more than the highest UNumberGroupingStrategy value.
0f5d89e8
A
264 *
265 * @internal ICU 62: The numeric value may change over time; see ICU ticket #12420.
266 */
267 UNUM_GROUPING_COUNT
3d1f044b
A
268#endif /* U_HIDE_INTERNAL_API */
269
270} UNumberGroupingStrategy;
271
0f5d89e8 272
0f5d89e8
A
273#endif /* U_HIDE_DRAFT_API */
274
275#ifndef U_HIDE_DRAFT_API
276/**
277 * An enum declaring how to denote positive and negative numbers. Example outputs when formatting
278 * 123, 0, and -123 in <em>en-US</em>:
279 *
280 * <ul>
281 * <li>AUTO: "123", "0", and "-123"
282 * <li>ALWAYS: "+123", "+0", and "-123"
283 * <li>NEVER: "123", "0", and "123"
284 * <li>ACCOUNTING: "$123", "$0", and "($123)"
285 * <li>ACCOUNTING_ALWAYS: "+$123", "+$0", and "($123)"
286 * <li>EXCEPT_ZERO: "+123", "0", and "-123"
287 * <li>ACCOUNTING_EXCEPT_ZERO: "+$123", "$0", and "($123)"
288 * </ul>
289 *
290 * <p>
291 * The exact format, including the position and the code point of the sign, differ by locale.
292 *
293 * @draft ICU 60
294 */
295typedef enum UNumberSignDisplay {
296 /**
297 * Show the minus sign on negative numbers, and do not show the sign on positive numbers. This is the default
298 * behavior.
299 *
300 * @draft ICU 60
301 */
302 UNUM_SIGN_AUTO,
303
304 /**
305 * Show the minus sign on negative numbers and the plus sign on positive numbers, including zero.
306 * To hide the sign on zero, see {@link UNUM_SIGN_EXCEPT_ZERO}.
307 *
308 * @draft ICU 60
309 */
310 UNUM_SIGN_ALWAYS,
311
312 /**
313 * Do not show the sign on positive or negative numbers.
314 *
315 * @draft ICU 60
316 */
317 UNUM_SIGN_NEVER,
318
319 /**
320 * Use the locale-dependent accounting format on negative numbers, and do not show the sign on positive numbers.
321 *
322 * <p>
323 * The accounting format is defined in CLDR and varies by locale; in many Western locales, the format is a pair
324 * of parentheses around the number.
325 *
326 * <p>
327 * Note: Since CLDR defines the accounting format in the monetary context only, this option falls back to the
328 * AUTO sign display strategy when formatting without a currency unit. This limitation may be lifted in the
329 * future.
330 *
331 * @draft ICU 60
332 */
333 UNUM_SIGN_ACCOUNTING,
334
335 /**
336 * Use the locale-dependent accounting format on negative numbers, and show the plus sign on
337 * positive numbers, including zero. For more information on the accounting format, see the
338 * ACCOUNTING sign display strategy. To hide the sign on zero, see
339 * {@link UNUM_SIGN_ACCOUNTING_EXCEPT_ZERO}.
340 *
341 * @draft ICU 60
342 */
343 UNUM_SIGN_ACCOUNTING_ALWAYS,
344
345 /**
346 * Show the minus sign on negative numbers and the plus sign on positive numbers. Do not show a
347 * sign on zero.
348 *
349 * @draft ICU 61
350 */
351 UNUM_SIGN_EXCEPT_ZERO,
352
353 /**
354 * Use the locale-dependent accounting format on negative numbers, and show the plus sign on
355 * positive numbers. Do not show a sign on zero. For more information on the accounting format,
356 * see the ACCOUNTING sign display strategy.
357 *
358 * @draft ICU 61
359 */
360 UNUM_SIGN_ACCOUNTING_EXCEPT_ZERO,
361
362 /**
363 * One more than the highest UNumberSignDisplay value.
364 *
365 * @internal ICU 60: The numeric value may change over time; see ICU ticket #12420.
366 */
367 UNUM_SIGN_COUNT
368} UNumberSignDisplay;
369#endif /* U_HIDE_DRAFT_API */
370
371#ifndef U_HIDE_DRAFT_API
372/**
373 * An enum declaring how to render the decimal separator.
374 *
375 * <p>
376 * <ul>
377 * <li>UNUM_DECIMAL_SEPARATOR_AUTO: "1", "1.1"
378 * <li>UNUM_DECIMAL_SEPARATOR_ALWAYS: "1.", "1.1"
379 * </ul>
3d1f044b
A
380 *
381 * @draft ICU 60
0f5d89e8
A
382 */
383typedef enum UNumberDecimalSeparatorDisplay {
384 /**
385 * Show the decimal separator when there are one or more digits to display after the separator, and do not show
386 * it otherwise. This is the default behavior.
387 *
388 * @draft ICU 60
389 */
390 UNUM_DECIMAL_SEPARATOR_AUTO,
391
392 /**
393 * Always show the decimal separator, even if there are no digits to display after the separator.
394 *
395 * @draft ICU 60
396 */
397 UNUM_DECIMAL_SEPARATOR_ALWAYS,
398
399 /**
400 * One more than the highest UNumberDecimalSeparatorDisplay value.
401 *
402 * @internal ICU 60: The numeric value may change over time; see ICU ticket #12420.
403 */
404 UNUM_DECIMAL_SEPARATOR_COUNT
405} UNumberDecimalSeparatorDisplay;
406#endif /* U_HIDE_DRAFT_API */
407
3d1f044b 408struct UNumberFormatter;
0f5d89e8
A
409/**
410 * C-compatible version of icu::number::LocalizedNumberFormatter.
411 *
412 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
413 *
3d1f044b 414 * @stable ICU 62
0f5d89e8 415 */
0f5d89e8
A
416typedef struct UNumberFormatter UNumberFormatter;
417
3d1f044b 418struct UFormattedNumber;
0f5d89e8
A
419/**
420 * C-compatible version of icu::number::FormattedNumber.
421 *
422 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
423 *
3d1f044b 424 * @stable ICU 62
0f5d89e8 425 */
0f5d89e8
A
426typedef struct UFormattedNumber UFormattedNumber;
427
428
429/**
430 * Creates a new UNumberFormatter for the given skeleton string and locale. This is currently the only
431 * method for creating a new UNumberFormatter.
432 *
433 * Objects of type UNumberFormatter returned by this method are threadsafe.
434 *
435 * For more details on skeleton strings, see the documentation in numberformatter.h. For more details on
436 * the usage of this API, see the documentation at the top of unumberformatter.h.
437 *
438 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
439 *
440 * @param skeleton The skeleton string, like u"percent precision-integer"
441 * @param skeletonLen The number of UChars in the skeleton string, or -1 it it is NUL-terminated.
442 * @param locale The NUL-terminated locale ID.
443 * @param ec Set if an error occurs.
3d1f044b 444 * @stable ICU 62
0f5d89e8 445 */
3d1f044b 446U_STABLE UNumberFormatter* U_EXPORT2
0f5d89e8
A
447unumf_openForSkeletonAndLocale(const UChar* skeleton, int32_t skeletonLen, const char* locale,
448 UErrorCode* ec);
449
450
3d1f044b 451#ifndef U_HIDE_DRAFT_API
0f5d89e8 452/**
3d1f044b
A
453 * Like unumf_openForSkeletonAndLocale, but accepts a UParseError, which will be populated with the
454 * location of a skeleton syntax error if such a syntax error exists.
0f5d89e8 455 *
3d1f044b
A
456 * @param skeleton The skeleton string, like u"percent precision-integer"
457 * @param skeletonLen The number of UChars in the skeleton string, or -1 it it is NUL-terminated.
458 * @param locale The NUL-terminated locale ID.
459 * @param perror A parse error struct populated if an error occurs when parsing. Can be NULL.
460 * If no error occurs, perror->offset will be set to -1.
461 * @param ec Set if an error occurs.
462 * @draft ICU 64
463 */
464U_DRAFT UNumberFormatter* U_EXPORT2
465unumf_openForSkeletonAndLocaleWithError(
466 const UChar* skeleton, int32_t skeletonLen, const char* locale, UParseError* perror, UErrorCode* ec);
467#endif // U_HIDE_DRAFT_API
468
469
470/**
471 * Creates an object to hold the result of a UNumberFormatter
472 * operation. The object can be used repeatedly; it is cleared whenever
473 * passed to a format function.
0f5d89e8
A
474 *
475 * @param ec Set if an error occurs.
3d1f044b 476 * @stable ICU 62
0f5d89e8 477 */
3d1f044b 478U_STABLE UFormattedNumber* U_EXPORT2
0f5d89e8
A
479unumf_openResult(UErrorCode* ec);
480
481
482/**
483 * Uses a UNumberFormatter to format an integer to a UFormattedNumber. A string, field position, and other
484 * information can be retrieved from the UFormattedNumber.
485 *
486 * The UNumberFormatter can be shared between threads. Each thread should have its own local
487 * UFormattedNumber, however, for storing the result of the formatting operation.
488 *
489 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
490 *
491 * @param uformatter A formatter object created by unumf_openForSkeletonAndLocale or similar.
492 * @param value The number to be formatted.
493 * @param uresult The object that will be mutated to store the result; see unumf_openResult.
494 * @param ec Set if an error occurs.
3d1f044b 495 * @stable ICU 62
0f5d89e8 496 */
3d1f044b 497U_STABLE void U_EXPORT2
0f5d89e8
A
498unumf_formatInt(const UNumberFormatter* uformatter, int64_t value, UFormattedNumber* uresult,
499 UErrorCode* ec);
500
501
502/**
503 * Uses a UNumberFormatter to format a double to a UFormattedNumber. A string, field position, and other
504 * information can be retrieved from the UFormattedNumber.
505 *
506 * The UNumberFormatter can be shared between threads. Each thread should have its own local
507 * UFormattedNumber, however, for storing the result of the formatting operation.
508 *
509 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
510 *
511 * @param uformatter A formatter object created by unumf_openForSkeletonAndLocale or similar.
512 * @param value The number to be formatted.
513 * @param uresult The object that will be mutated to store the result; see unumf_openResult.
514 * @param ec Set if an error occurs.
3d1f044b 515 * @stable ICU 62
0f5d89e8 516 */
3d1f044b 517U_STABLE void U_EXPORT2
0f5d89e8
A
518unumf_formatDouble(const UNumberFormatter* uformatter, double value, UFormattedNumber* uresult,
519 UErrorCode* ec);
520
521
522/**
523 * Uses a UNumberFormatter to format a decimal number to a UFormattedNumber. A string, field position, and
524 * other information can be retrieved from the UFormattedNumber.
525 *
526 * The UNumberFormatter can be shared between threads. Each thread should have its own local
527 * UFormattedNumber, however, for storing the result of the formatting operation.
528 *
529 * The syntax of the unformatted number is a "numeric string" as defined in the Decimal Arithmetic
530 * Specification, available at http://speleotrove.com/decimal
531 *
532 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
533 *
534 * @param uformatter A formatter object created by unumf_openForSkeletonAndLocale or similar.
535 * @param value The numeric string to be formatted.
536 * @param valueLen The length of the numeric string, or -1 if it is NUL-terminated.
537 * @param uresult The object that will be mutated to store the result; see unumf_openResult.
538 * @param ec Set if an error occurs.
3d1f044b 539 * @stable ICU 62
0f5d89e8 540 */
3d1f044b 541U_STABLE void U_EXPORT2
0f5d89e8
A
542unumf_formatDecimal(const UNumberFormatter* uformatter, const char* value, int32_t valueLen,
543 UFormattedNumber* uresult, UErrorCode* ec);
544
3d1f044b
A
545#ifndef U_HIDE_DRAFT_API
546/**
547 * Returns a representation of a UFormattedNumber as a UFormattedValue,
548 * which can be subsequently passed to any API requiring that type.
549 *
550 * The returned object is owned by the UFormattedNumber and is valid
551 * only as long as the UFormattedNumber is present and unchanged in memory.
552 *
553 * You can think of this method as a cast between types.
554 *
555 * @param uresult The object containing the formatted string.
556 * @param ec Set if an error occurs.
557 * @return A UFormattedValue owned by the input object.
558 * @draft ICU 64
559 */
560U_DRAFT const UFormattedValue* U_EXPORT2
561unumf_resultAsValue(const UFormattedNumber* uresult, UErrorCode* ec);
562#endif /* U_HIDE_DRAFT_API */
563
0f5d89e8
A
564
565/**
566 * Extracts the result number string out of a UFormattedNumber to a UChar buffer if possible.
567 * If bufferCapacity is greater than the required length, a terminating NUL is written.
568 * If bufferCapacity is less than the required length, an error code is set.
569 *
3d1f044b
A
570 * Also see ufmtval_getString, which returns a NUL-terminated string:
571 *
572 * int32_t len;
573 * const UChar* str = ufmtval_getString(unumf_resultAsValue(uresult, &ec), &len, &ec);
574 *
0f5d89e8
A
575 * NOTE: This is a C-compatible API; C++ users should build against numberformatter.h instead.
576 *
577 * @param uresult The object containing the formatted number.
578 * @param buffer Where to save the string output.
579 * @param bufferCapacity The number of UChars available in the buffer.
580 * @param ec Set if an error occurs.
581 * @return The required length.
3d1f044b 582 * @stable ICU 62
0f5d89e8 583 */
3d1f044b 584U_STABLE int32_t U_EXPORT2
0f5d89e8
A
585unumf_resultToString(const UFormattedNumber* uresult, UChar* buffer, int32_t bufferCapacity,
586 UErrorCode* ec);
587
588
589/**
590 * Determines the start and end indices of the next occurrence of the given <em>field</em> in the
591 * output string. This allows you to determine the locations of, for example, the integer part,
592 * fraction part, or symbols.
593 *
3d1f044b
A
594 * This is a simpler but less powerful alternative to {@link ufmtval_nextPosition}.
595 *
0f5d89e8
A
596 * If a field occurs just once, calling this method will find that occurrence and return it. If a
597 * field occurs multiple times, this method may be called repeatedly with the following pattern:
598 *
599 * <pre>
600 * UFieldPosition ufpos = {UNUM_GROUPING_SEPARATOR_FIELD, 0, 0};
601 * while (unumf_resultNextFieldPosition(uresult, ufpos, &ec)) {
602 * // do something with ufpos.
603 * }
604 * </pre>
605 *
606 * This method is useful if you know which field to query. If you want all available field position
607 * information, use unumf_resultGetAllFieldPositions().
608 *
609 * NOTE: All fields of the UFieldPosition must be initialized before calling this method.
610 *
3d1f044b
A
611 * @param uresult The object containing the formatted number.
612 * @param ufpos
0f5d89e8
A
613 * Input+output variable. On input, the "field" property determines which field to look up,
614 * and the "endIndex" property determines where to begin the search. On output, the
615 * "beginIndex" field is set to the beginning of the first occurrence of the field after the
616 * input "endIndex", and "endIndex" is set to the end of that occurrence of the field
617 * (exclusive index). If a field position is not found, the FieldPosition is not changed and
618 * the method returns FALSE.
619 * @param ec Set if an error occurs.
3d1f044b 620 * @stable ICU 62
0f5d89e8 621 */
3d1f044b 622U_STABLE UBool U_EXPORT2
0f5d89e8
A
623unumf_resultNextFieldPosition(const UFormattedNumber* uresult, UFieldPosition* ufpos, UErrorCode* ec);
624
625
626/**
627 * Populates the given iterator with all fields in the formatted output string. This allows you to
628 * determine the locations of the integer part, fraction part, and sign.
629 *
3d1f044b
A
630 * This is an alternative to the more powerful {@link ufmtval_nextPosition} API.
631 *
632 * If you need information on only one field, use {@link ufmtval_nextPosition} or
633 * {@link unumf_resultNextFieldPosition}.
0f5d89e8
A
634 *
635 * @param uresult The object containing the formatted number.
3d1f044b 636 * @param ufpositer
0f5d89e8
A
637 * A pointer to a UFieldPositionIterator created by {@link #ufieldpositer_open}. Iteration
638 * information already present in the UFieldPositionIterator is deleted, and the iterator is reset
639 * to apply to the fields in the formatted string created by this function call. The field values
640 * and indexes returned by {@link #ufieldpositer_next} represent fields denoted by
641 * the UNumberFormatFields enum. Fields are not returned in a guaranteed order. Fields cannot
642 * overlap, but they may nest. For example, 1234 could format as "1,234" which might consist of a
643 * grouping separator field for ',' and an integer field encompassing the entire string.
644 * @param ec Set if an error occurs.
3d1f044b 645 * @stable ICU 62
0f5d89e8 646 */
3d1f044b 647U_STABLE void U_EXPORT2
0f5d89e8
A
648unumf_resultGetAllFieldPositions(const UFormattedNumber* uresult, UFieldPositionIterator* ufpositer,
649 UErrorCode* ec);
650
651
652/**
653 * Releases the UNumberFormatter created by unumf_openForSkeletonAndLocale().
654 *
0f5d89e8 655 * @param uformatter An object created by unumf_openForSkeletonAndLocale().
3d1f044b 656 * @stable ICU 62
0f5d89e8 657 */
3d1f044b 658U_STABLE void U_EXPORT2
0f5d89e8
A
659unumf_close(UNumberFormatter* uformatter);
660
661
662/**
663 * Releases the UFormattedNumber created by unumf_openResult().
664 *
0f5d89e8 665 * @param uresult An object created by unumf_openResult().
3d1f044b 666 * @stable ICU 62
0f5d89e8 667 */
3d1f044b 668U_STABLE void U_EXPORT2
0f5d89e8
A
669unumf_closeResult(UFormattedNumber* uresult);
670
671
672#if U_SHOW_CPLUSPLUS_API
673U_NAMESPACE_BEGIN
674
675/**
676 * \class LocalUNumberFormatterPointer
677 * "Smart pointer" class; closes a UNumberFormatter via unumf_close().
678 * For most methods see the LocalPointerBase base class.
679 *
680 * Usage:
681 * <pre>
682 * LocalUNumberFormatterPointer uformatter(unumf_openForSkeletonAndLocale(...));
683 * // no need to explicitly call unumf_close()
684 * </pre>
685 *
686 * @see LocalPointerBase
687 * @see LocalPointer
3d1f044b 688 * @stable ICU 62
0f5d89e8
A
689 */
690U_DEFINE_LOCAL_OPEN_POINTER(LocalUNumberFormatterPointer, UNumberFormatter, unumf_close);
691
692/**
3d1f044b 693 * \class LocalUFormattedNumberPointer
0f5d89e8
A
694 * "Smart pointer" class; closes a UFormattedNumber via unumf_closeResult().
695 * For most methods see the LocalPointerBase base class.
696 *
697 * Usage:
698 * <pre>
699 * LocalUFormattedNumberPointer uformatter(unumf_openResult(...));
700 * // no need to explicitly call unumf_closeResult()
701 * </pre>
702 *
703 * @see LocalPointerBase
704 * @see LocalPointer
3d1f044b 705 * @stable ICU 62
0f5d89e8
A
706 */
707U_DEFINE_LOCAL_OPEN_POINTER(LocalUFormattedNumberPointer, UFormattedNumber, unumf_closeResult);
708
709U_NAMESPACE_END
710#endif // U_SHOW_CPLUSPLUS_API
711
0f5d89e8
A
712#endif //__UNUMBERFORMATTER_H__
713#endif /* #if !UCONFIG_NO_FORMATTING */