• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2 **
3 ** Copyright 2010, The Android Open Source Project
4 **
5 ** Licensed under the Apache License, Version 2.0 (the "License");
6 ** you may not use this file except in compliance with the License.
7 ** You may obtain a copy of the License at
8 **
9 **     http://www.apache.org/licenses/LICENSE-2.0
10 **
11 ** Unless required by applicable law or agreed to in writing, software
12 ** distributed under the License is distributed on an "AS IS" BASIS,
13 ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 ** See the License for the specific language governing permissions and
15 ** limitations under the License.
16 */
17 
18 #ifndef _ANDROID_PHONEBOOK_INDEX_H
19 #define _ANDROID_PHONEBOOK_INDEX_H
20 
21 #include <unicode/uiter.h>
22 #include <unicode/utypes.h>
23 
24 namespace android {
25 
26 /**
27  * A character converter that takes a UNICODE character and produces the
28  * phone book index for it in the specified locale. For example, "a" becomes "A"
29  * and so does A with accents. Conversion rules differ from locale
30  * locale, which is why this function takes locale as an argument.
31  *
32  * @param iter iterator if input characters
33  * @param locale the string representation of the current locale, e.g. "ja"
34  * @param out output buffer
35  * @param size size of the output buffer in bytes. The buffer should be large enough
36  *        to hold the longest phone book index (e.g. a three-char word in Japan).
37  * @param isError will be set to TRUE if an error occurs
38  *
39  * @return number of characters returned
40  */
41 int32_t GetPhonebookIndex(UCharIterator * iter, const char * locale, UChar * out, int32_t size,
42         UBool * isError);
43 
44 }  // namespace android
45 
46 #endif
47