]>
Commit | Line | Data |
---|---|---|
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 | |
6 | * and others. All Rights Reserved. | |
7 | ******************************************************************************* | |
8 | * standardplural.cpp | |
9 | * | |
10 | * created on: 2015dec14 | |
11 | * created by: Markus W. Scherer | |
12 | */ | |
13 | ||
14 | #include "unicode/utypes.h" | |
15 | ||
16 | #if !UCONFIG_NO_FORMATTING | |
17 | ||
18 | #include "unicode/unistr.h" | |
19 | #include "cstring.h" | |
20 | #include "standardplural.h" | |
21 | #include "uassert.h" | |
22 | ||
23 | U_NAMESPACE_BEGIN | |
24 | ||
25 | static const char *gKeywords[StandardPlural::COUNT] = { | |
26 | "zero", "one", "two", "few", "many", "other" | |
27 | }; | |
28 | ||
29 | const char *StandardPlural::getKeyword(Form p) { | |
30 | U_ASSERT(ZERO <= p && p < COUNT); | |
31 | return gKeywords[p]; | |
32 | } | |
33 | ||
34 | int32_t StandardPlural::indexOrNegativeFromString(const char *keyword) { | |
35 | switch (*keyword++) { | |
36 | case 'f': | |
37 | if (uprv_strcmp(keyword, "ew") == 0) { | |
38 | return FEW; | |
39 | } | |
40 | break; | |
41 | case 'm': | |
42 | if (uprv_strcmp(keyword, "any") == 0) { | |
43 | return MANY; | |
44 | } | |
45 | break; | |
46 | case 'o': | |
47 | if (uprv_strcmp(keyword, "ther") == 0) { | |
48 | return OTHER; | |
49 | } else if (uprv_strcmp(keyword, "ne") == 0) { | |
50 | return ONE; | |
51 | } | |
52 | break; | |
53 | case 't': | |
54 | if (uprv_strcmp(keyword, "wo") == 0) { | |
55 | return TWO; | |
56 | } | |
57 | break; | |
58 | case 'z': | |
59 | if (uprv_strcmp(keyword, "ero") == 0) { | |
60 | return ZERO; | |
61 | } | |
62 | break; | |
63 | default: | |
64 | break; | |
65 | } | |
66 | return -1; | |
67 | } | |
68 | ||
69 | static const UChar gZero[] = { 0x7A, 0x65, 0x72, 0x6F }; | |
70 | static const UChar gOne[] = { 0x6F, 0x6E, 0x65 }; | |
71 | static const UChar gTwo[] = { 0x74, 0x77, 0x6F }; | |
72 | static const UChar gFew[] = { 0x66, 0x65, 0x77 }; | |
73 | static const UChar gMany[] = { 0x6D, 0x61, 0x6E, 0x79 }; | |
74 | static const UChar gOther[] = { 0x6F, 0x74, 0x68, 0x65, 0x72 }; | |
75 | ||
76 | int32_t StandardPlural::indexOrNegativeFromString(const UnicodeString &keyword) { | |
77 | switch (keyword.length()) { | |
78 | case 3: | |
79 | if (keyword.compare(gOne, 3) == 0) { | |
80 | return ONE; | |
81 | } else if (keyword.compare(gTwo, 3) == 0) { | |
82 | return TWO; | |
83 | } else if (keyword.compare(gFew, 3) == 0) { | |
84 | return FEW; | |
85 | } | |
86 | break; | |
87 | case 4: | |
88 | if (keyword.compare(gMany, 4) == 0) { | |
89 | return MANY; | |
90 | } else if (keyword.compare(gZero, 4) == 0) { | |
91 | return ZERO; | |
92 | } | |
93 | break; | |
94 | case 5: | |
95 | if (keyword.compare(gOther, 5) == 0) { | |
96 | return OTHER; | |
97 | } | |
98 | break; | |
99 | default: | |
100 | break; | |
101 | } | |
102 | return -1; | |
103 | } | |
104 | ||
105 | int32_t StandardPlural::indexFromString(const char *keyword, UErrorCode &errorCode) { | |
106 | if (U_FAILURE(errorCode)) { return OTHER; } | |
107 | int32_t i = indexOrNegativeFromString(keyword); | |
108 | if (i >= 0) { | |
109 | return i; | |
110 | } else { | |
111 | errorCode = U_ILLEGAL_ARGUMENT_ERROR; | |
112 | return OTHER; | |
113 | } | |
114 | } | |
115 | ||
116 | int32_t StandardPlural::indexFromString(const UnicodeString &keyword, UErrorCode &errorCode) { | |
117 | if (U_FAILURE(errorCode)) { return OTHER; } | |
118 | int32_t i = indexOrNegativeFromString(keyword); | |
119 | if (i >= 0) { | |
120 | return i; | |
121 | } else { | |
122 | errorCode = U_ILLEGAL_ARGUMENT_ERROR; | |
123 | return OTHER; | |
124 | } | |
125 | } | |
126 | ||
127 | U_NAMESPACE_END | |
128 | ||
129 | #endif // !UCONFIG_NO_FORMATTING |