]>
Commit | Line | Data |
---|---|---|
1 | /* | |
2 | ******************************************************************************* | |
3 | * | |
4 | * Copyright (C) 1998-2011, International Business Machines | |
5 | * Corporation and others. All Rights Reserved. | |
6 | * | |
7 | ******************************************************************************* | |
8 | * | |
9 | * File locbund.h | |
10 | * | |
11 | * Modification History: | |
12 | * | |
13 | * Date Name Description | |
14 | * 10/16/98 stephen Creation. | |
15 | * 02/25/99 stephen Modified for new C API. | |
16 | ******************************************************************************* | |
17 | */ | |
18 | ||
19 | #ifndef LOCBUND_H | |
20 | #define LOCBUND_H | |
21 | ||
22 | #include "unicode/utypes.h" | |
23 | ||
24 | #if !UCONFIG_NO_FORMATTING | |
25 | ||
26 | #include "unicode/unum.h" | |
27 | ||
28 | #define ULOCALEBUNDLE_NUMBERFORMAT_COUNT ((int32_t)UNUM_SPELLOUT) | |
29 | ||
30 | typedef struct ULocaleBundle { | |
31 | char *fLocale; | |
32 | ||
33 | UNumberFormat *fNumberFormat[ULOCALEBUNDLE_NUMBERFORMAT_COUNT]; | |
34 | UBool isInvariantLocale; | |
35 | } ULocaleBundle; | |
36 | ||
37 | ||
38 | /** | |
39 | * Initialize a ULocaleBundle, initializing all formatters to 0. | |
40 | * @param result A ULocaleBundle to initialize. | |
41 | * @param loc The locale of the ULocaleBundle. | |
42 | * @return A pointer to a ULocaleBundle, or 0 if <TT>loc</TT> was invalid. | |
43 | */ | |
44 | U_CAPI ULocaleBundle * | |
45 | u_locbund_init(ULocaleBundle *result, const char *loc); | |
46 | ||
47 | /** | |
48 | * Create a new ULocaleBundle, initializing all formatters to 0. | |
49 | * @param loc The locale of the ULocaleBundle. | |
50 | * @return A pointer to a ULocaleBundle, or 0 if <TT>loc</TT> was invalid. | |
51 | */ | |
52 | /*U_CAPI ULocaleBundle * | |
53 | u_locbund_new(const char *loc);*/ | |
54 | ||
55 | /** | |
56 | * Create a deep copy of this ULocaleBundle; | |
57 | * @param bundle The ULocaleBundle to clone. | |
58 | * @return A new ULocaleBundle. | |
59 | */ | |
60 | /*U_CAPI ULocaleBundle * | |
61 | u_locbund_clone(const ULocaleBundle *bundle);*/ | |
62 | ||
63 | /** | |
64 | * Delete the specified ULocaleBundle, freeing all associated memory. | |
65 | * @param bundle The ULocaleBundle to delete | |
66 | */ | |
67 | U_CAPI void | |
68 | u_locbund_close(ULocaleBundle *bundle); | |
69 | ||
70 | /** | |
71 | * Get the NumberFormat used to format and parse numbers in a ULocaleBundle. | |
72 | * @param bundle The ULocaleBundle to use | |
73 | * @return A pointer to the NumberFormat used for number formatting and parsing. | |
74 | */ | |
75 | U_CAPI UNumberFormat * | |
76 | u_locbund_getNumberFormat(ULocaleBundle *bundle, UNumberFormatStyle style); | |
77 | ||
78 | #endif /* #if !UCONFIG_NO_FORMATTING */ | |
79 | ||
80 | #endif |