X-Git-Url: https://git.saurik.com/apple/icu.git/blobdiff_plain/b75a7d8f3b4adbae880cab104ce2c6a50eee4db2..374ca955a76ecab1204ca8bfa63ff9238d998416:/icuSources/tools/toolutil/propsvec.h diff --git a/icuSources/tools/toolutil/propsvec.h b/icuSources/tools/toolutil/propsvec.h new file mode 100644 index 00000000..86d214f9 --- /dev/null +++ b/icuSources/tools/toolutil/propsvec.h @@ -0,0 +1,78 @@ +/* +******************************************************************************* +* +* Copyright (C) 2002-2004, International Business Machines +* Corporation and others. All Rights Reserved. +* +******************************************************************************* +* file name: propsvec.h +* encoding: US-ASCII +* tab size: 8 (not used) +* indentation:4 +* +* created on: 2002feb22 +* created by: Markus W. Scherer +* +* Store additional Unicode character properties in bit set vectors. +*/ + +#ifndef __UPROPSVEC_H__ +#define __UPROPSVEC_H__ + +#include "unicode/utypes.h" +#include "utrie.h" + +/* + * Unicode Properties Vectors associated with code point ranges. + * Stored in an array of uint32_t. + * + * The array starts with a header, then rows of integers store + * the range limits and the properties vectors. + * + * In each row, row[0] contains the start code point and + * row[1] contains the limit code point, + * which is the start of the next range. + * + * Initially, there is only one range [0..0x110000[ with values 0. + * + * It would be possible to store only one range boundary per row, + * but self-contained rows allow to later sort them by contents. + */ +enum { + /* stores number of columns, plus two for start & limit values */ + UPVEC_COLUMNS, + UPVEC_MAXROWS, + UPVEC_ROWS, + /* search optimization: remember last row seen */ + UPVEC_PREV_ROW, + UPVEC_HEADER_LENGTH +}; + +U_CAPI uint32_t * U_EXPORT2 +upvec_open(int32_t columns, int32_t maxRows); + +U_CAPI void U_EXPORT2 +upvec_close(uint32_t *pv); + +U_CAPI UBool U_EXPORT2 +upvec_setValue(uint32_t *pv, + UChar32 start, UChar32 limit, + int32_t column, + uint32_t value, uint32_t mask, + UErrorCode *pErrorCode); + +U_CAPI uint32_t U_EXPORT2 +upvec_getValue(uint32_t *pv, UChar32 c, int32_t column); + +/* + * pRangeStart and pRangeLimit can be NULL. + * @return NULL if rowIndex out of range and for illegal arguments + */ +U_CAPI uint32_t * U_EXPORT2 +upvec_getRow(uint32_t *pv, int32_t rowIndex, + UChar32 *pRangeStart, UChar32 *pRangeLimit); + +U_CAPI int32_t U_EXPORT2 +upvec_toTrie(uint32_t *pv, UNewTrie *trie, UErrorCode *pErrorCode); + +#endif