| 1 | // © 2016 and later: Unicode, Inc. and others. | 
|---|
| 2 | // License & terms of use: http://www.unicode.org/copyright.html | 
|---|
| 3 | /* | 
|---|
| 4 | ********************************************************************** | 
|---|
| 5 | *   Copyright (C) 1999-2006, International Business Machines | 
|---|
| 6 | *   Corporation and others.  All Rights Reserved. | 
|---|
| 7 | ********************************************************************** | 
|---|
| 8 | * | 
|---|
| 9 | * | 
|---|
| 10 | *  ucnv_io.h: | 
|---|
| 11 | *  defines  variables and functions pertaining to converter name resolution | 
|---|
| 12 | *  aspect of the conversion code | 
|---|
| 13 | */ | 
|---|
| 14 |  | 
|---|
| 15 | #ifndef UCNV_IO_H | 
|---|
| 16 | #define UCNV_IO_H | 
|---|
| 17 |  | 
|---|
| 18 | #include "unicode/utypes.h" | 
|---|
| 19 |  | 
|---|
| 20 | #if !UCONFIG_NO_CONVERSION | 
|---|
| 21 |  | 
|---|
| 22 | #include "udataswp.h" | 
|---|
| 23 |  | 
|---|
| 24 | #define UCNV_AMBIGUOUS_ALIAS_MAP_BIT 0x8000 | 
|---|
| 25 | #define UCNV_CONTAINS_OPTION_BIT 0x4000 | 
|---|
| 26 | #define UCNV_CONVERTER_INDEX_MASK 0xFFF | 
|---|
| 27 | #define UCNV_NUM_RESERVED_TAGS 2 | 
|---|
| 28 | #define UCNV_NUM_HIDDEN_TAGS 1 | 
|---|
| 29 |  | 
|---|
| 30 | enum { | 
|---|
| 31 | UCNV_IO_UNNORMALIZED, | 
|---|
| 32 | UCNV_IO_STD_NORMALIZED, | 
|---|
| 33 | UCNV_IO_NORM_TYPE_COUNT | 
|---|
| 34 | }; | 
|---|
| 35 |  | 
|---|
| 36 | typedef struct { | 
|---|
| 37 | uint16_t stringNormalizationType; | 
|---|
| 38 | uint16_t containsCnvOptionInfo; | 
|---|
| 39 | } UConverterAliasOptions; | 
|---|
| 40 |  | 
|---|
| 41 | typedef struct UConverterAlias { | 
|---|
| 42 | const uint16_t *converterList; | 
|---|
| 43 | const uint16_t *tagList; | 
|---|
| 44 | const uint16_t *aliasList; | 
|---|
| 45 | const uint16_t *untaggedConvArray; | 
|---|
| 46 | const uint16_t *taggedAliasArray; | 
|---|
| 47 | const uint16_t *taggedAliasLists; | 
|---|
| 48 | const UConverterAliasOptions *optionTable; | 
|---|
| 49 | const uint16_t *stringTable; | 
|---|
| 50 | const uint16_t *normalizedStringTable; | 
|---|
| 51 |  | 
|---|
| 52 | uint32_t converterListSize; | 
|---|
| 53 | uint32_t tagListSize; | 
|---|
| 54 | uint32_t aliasListSize; | 
|---|
| 55 | uint32_t untaggedConvArraySize; | 
|---|
| 56 | uint32_t taggedAliasArraySize; | 
|---|
| 57 | uint32_t taggedAliasListsSize; | 
|---|
| 58 | uint32_t optionTableSize; | 
|---|
| 59 | uint32_t stringTableSize; | 
|---|
| 60 | uint32_t normalizedStringTableSize; | 
|---|
| 61 | } UConverterAlias; | 
|---|
| 62 |  | 
|---|
| 63 | /** | 
|---|
| 64 | * \var ucnv_io_stripForCompare | 
|---|
| 65 | * Remove the underscores, dashes and spaces from the name, and convert | 
|---|
| 66 | * the name to lower case. | 
|---|
| 67 | * @param dst The destination buffer, which is <= the buffer of name. | 
|---|
| 68 | * @param dst The destination buffer, which is <= the buffer of name. | 
|---|
| 69 | * @see ucnv_compareNames | 
|---|
| 70 | * @return the destination buffer. | 
|---|
| 71 | */ | 
|---|
| 72 | #if U_CHARSET_FAMILY==U_ASCII_FAMILY | 
|---|
| 73 | #   define ucnv_io_stripForCompare ucnv_io_stripASCIIForCompare | 
|---|
| 74 | #elif U_CHARSET_FAMILY==U_EBCDIC_FAMILY | 
|---|
| 75 | #   define ucnv_io_stripForCompare ucnv_io_stripEBCDICForCompare | 
|---|
| 76 | #else | 
|---|
| 77 | #   error U_CHARSET_FAMILY is not valid | 
|---|
| 78 | #endif | 
|---|
| 79 |  | 
|---|
| 80 | U_CAPI char * U_CALLCONV | 
|---|
| 81 | ucnv_io_stripASCIIForCompare(char *dst, const char *name); | 
|---|
| 82 |  | 
|---|
| 83 | U_CAPI char * U_CALLCONV | 
|---|
| 84 | ucnv_io_stripEBCDICForCompare(char *dst, const char *name); | 
|---|
| 85 |  | 
|---|
| 86 | /** | 
|---|
| 87 | * Map a converter alias name to a canonical converter name. | 
|---|
| 88 | * The alias is searched for case-insensitively, the converter name | 
|---|
| 89 | * is returned in mixed-case. | 
|---|
| 90 | * Returns NULL if the alias is not found. | 
|---|
| 91 | * @param alias The alias name to be searched. | 
|---|
| 92 | * @param containsOption A return value stating whether the returned converter name contains an option (a comma) | 
|---|
| 93 | * @param pErrorCode The error code | 
|---|
| 94 | * @return the converter name in mixed-case, return NULL if the alias is not found. | 
|---|
| 95 | */ | 
|---|
| 96 | U_CAPI const char * | 
|---|
| 97 | ucnv_io_getConverterName(const char *alias, UBool *containsOption, UErrorCode *pErrorCode); | 
|---|
| 98 |  | 
|---|
| 99 | /** | 
|---|
| 100 | * Return the number of all known converter names (no aliases). | 
|---|
| 101 | * @param pErrorCode The error code | 
|---|
| 102 | * @return the number of all aliases | 
|---|
| 103 | */ | 
|---|
| 104 | U_CAPI uint16_t | 
|---|
| 105 | ucnv_io_countKnownConverters(UErrorCode *pErrorCode); | 
|---|
| 106 |  | 
|---|
| 107 | /** | 
|---|
| 108 | * Swap an ICU converter alias table. See implementation for details. | 
|---|
| 109 | * @internal | 
|---|
| 110 | */ | 
|---|
| 111 | U_CAPI int32_t U_EXPORT2 | 
|---|
| 112 | ucnv_swapAliases(const UDataSwapper *ds, | 
|---|
| 113 | const void *inData, int32_t length, void *outData, | 
|---|
| 114 | UErrorCode *pErrorCode); | 
|---|
| 115 |  | 
|---|
| 116 | #endif | 
|---|
| 117 |  | 
|---|
| 118 | #endif /* _UCNV_IO */ | 
|---|
| 119 |  | 
|---|
| 120 | /* | 
|---|
| 121 | * Hey, Emacs, please set the following: | 
|---|
| 122 | * | 
|---|
| 123 | * Local Variables: | 
|---|
| 124 | * indent-tabs-mode: nil | 
|---|
| 125 | * End: | 
|---|
| 126 | * | 
|---|
| 127 | */ | 
|---|
| 128 |  | 
|---|