2000-02-03 19:54:49 +00:00
|
|
|
/*
|
|
|
|
*******************************************************************************
|
|
|
|
*
|
2001-03-21 20:44:20 +00:00
|
|
|
* Copyright (C) 1999-2001, International Business Machines
|
2000-02-03 19:54:49 +00:00
|
|
|
* Corporation and others. All Rights Reserved.
|
|
|
|
*
|
|
|
|
*******************************************************************************
|
|
|
|
* file name: utf.h
|
|
|
|
* encoding: US-ASCII
|
|
|
|
* tab size: 8 (not used)
|
|
|
|
* indentation:4
|
|
|
|
*
|
|
|
|
* created on: 1999sep09
|
|
|
|
* created by: Markus W. Scherer
|
2000-12-08 18:43:57 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
2000-12-12 20:31:47 +00:00
|
|
|
* \brief C API: UChar and UChar32 data types and UTF macros for C Unicode string handling
|
2000-02-03 19:54:49 +00:00
|
|
|
*
|
2000-12-12 20:31:47 +00:00
|
|
|
* <p>This file defines the UChar and UChar32 data types for Unicode code units
|
2000-02-03 19:54:49 +00:00
|
|
|
* and code points, as well as macros for efficiently getting code points
|
2000-12-12 20:31:47 +00:00
|
|
|
* in and out of a string.</p>
|
|
|
|
*
|
|
|
|
* <p>utf.h is included by utypes.h and itself includes the utfXX.h after some
|
|
|
|
* common definitions. Those files define the macros for each UTF-size.</p>
|
|
|
|
*
|
2001-10-12 18:53:26 +00:00
|
|
|
* <p>The original concept for these files was for ICU to allow
|
|
|
|
* in principle to set which UTF (UTF-8/16/32) is used internally
|
2000-12-12 20:31:47 +00:00
|
|
|
* by defining UTF_SIZE to either 8, 16, or 32. utf.h would then define the UChar type
|
2001-10-12 18:53:26 +00:00
|
|
|
* accordingly. UTF-16 was the default.</p>
|
2000-12-12 20:31:47 +00:00
|
|
|
*
|
2001-10-12 18:53:26 +00:00
|
|
|
* <p>This concept has been abandoned.
|
|
|
|
* A lot of the ICU source code — especially low-level code like
|
|
|
|
* conversion, normalization, and collation — assumes UTF-16,
|
|
|
|
* utf.h enforces the default of UTF-16.
|
|
|
|
* The UTF-8 and UTF-32 macros remain for now for completeness and backward compatibility.</p>
|
|
|
|
*
|
|
|
|
* <p>Accordingly, utf.h defines UChar to be an unsigned 16-bit integer. If this matches wchar_t, then
|
2000-12-12 20:31:47 +00:00
|
|
|
* UChar is defined to be exactly wchar_t, otherwise uint16_t.</p>
|
|
|
|
*
|
|
|
|
* <p>UChar32 is always defined to be a 32-bit integer to be large enough for a 21-bit
|
|
|
|
* Unicode code point (Unicode scalar value, 0..0x10ffff). If wchar_t is a 32-bit type, then
|
|
|
|
* UChar32 is defined to be exactly wchar_t, <em>regardless of whether wchar_t is signed or unsigned.
|
|
|
|
* This means that UChar32 may be signed or unsigned depending on the platform!</em>
|
|
|
|
* If wchar_t is not a 32-bit type, then UChar32 is defined to be uint32_t.</p>
|
|
|
|
*
|
|
|
|
* <p>utf.h also defines a number of C macros for handling single Unicode code points and
|
|
|
|
* for using UTF Unicode strings. It includes utf8.h, utf16.h, and utf32.h for the actual
|
|
|
|
* implementations of those macros and then aliases one set of them (for UTF-16) for general use.
|
|
|
|
* The UTF-specific macros have the UTF size in the macro name prefixes (UTF16_...), while
|
|
|
|
* the general alias macros always begin with UTF_...</p>
|
|
|
|
*
|
|
|
|
* <p>Many string operations can be done with or without error checking.
|
|
|
|
* Where such a distinction is useful, there are two versions of the macros, "unsafe" and "safe"
|
|
|
|
* ones with ..._UNSAFE and ..._SAFE suffixes. The unsafe macros are fast but may cause
|
|
|
|
* program failures if the strings are not well-formed. The safe macros have an additional, boolean
|
|
|
|
* parameter "strict". If strict is FALSE, then only illegal sequences are detected.
|
2001-10-12 18:53:26 +00:00
|
|
|
* Otherwise, irregular sequences and non-characters are detected as well (like single surrogates).
|
2000-12-12 20:31:47 +00:00
|
|
|
* Safe macros return special error code points for illegal/irregular sequences:
|
2001-10-12 18:53:26 +00:00
|
|
|
* Typically, U+ffff, or values that would result in a code unit sequence of the same length
|
|
|
|
* as the erroneous input sequence.<br>
|
2000-12-15 18:22:39 +00:00
|
|
|
* Note that _UNSAFE macros have fewer parameters: They do not have the strictness parameter, and
|
|
|
|
* they do not have start/length parameters for boundary checking.</p>
|
2000-12-12 20:31:47 +00:00
|
|
|
*
|
2000-12-15 18:22:39 +00:00
|
|
|
* <p>Here, the macros are aliased in two steps:
|
|
|
|
* In the first step, the UTF-specific macros with UTF16_ prefix and _UNSAFE and _SAFE suffixes are
|
|
|
|
* aliased according to the UTF_SIZE to macros with UTF_ prefix and the same suffixes and signatures.
|
|
|
|
* Then, in a second step, the default, general alias macros are set to use either the unsafe or
|
|
|
|
* the safe/not strict (default) or the safe/strict macro;
|
|
|
|
* these general macros do not have a strictness parameter.</p>
|
|
|
|
*
|
|
|
|
* <p>It is possible to change the default choice for the general alias macros to be unsafe, safe/not strict or safe/strict.
|
2000-12-12 20:31:47 +00:00
|
|
|
* The default is safe/not strict. It is not recommended to select the unsafe macros as the basis for
|
|
|
|
* Unicode string handling in ICU! To select this, define UTF_SAFE, UTF_STRICT, or UTF_UNSAFE.</p>
|
2000-12-15 18:22:39 +00:00
|
|
|
*
|
|
|
|
* <p>For general use, one should use the default, general macros with UTF_ prefix and no _SAFE/_UNSAFE suffix.
|
|
|
|
* Only in some cases it may be necessary to control the choice of macro directly and use a less generic alias.
|
|
|
|
* For example, if it can be assumed that a string is well-formed and the index will stay within the bounds,
|
|
|
|
* then the _UNSAFE version may be used.
|
2001-03-22 19:56:47 +00:00
|
|
|
* If a UTF-8 string is to be processed, then the macros with UTF8_ prefixes need to be used.</p>
|
2001-03-22 20:07:44 +00:00
|
|
|
* <p><b>Usage:</b> ICU coding guidelines for if() statements should be followed when using these macros.
|
2001-03-22 19:41:37 +00:00
|
|
|
* Compound statements (curly braces {}) must be used for if-else-while...
|
2001-03-22 20:07:44 +00:00
|
|
|
* bodies and all macro statements should be terminated with semicolon.</p>
|
2000-02-03 19:54:49 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __UTF_H__
|
|
|
|
#define __UTF_H__
|
|
|
|
|
2000-04-01 00:17:55 +00:00
|
|
|
/*
|
|
|
|
* ANSI C headers:
|
|
|
|
* stddef.h defines wchar_t
|
|
|
|
*/
|
|
|
|
#include <stddef.h>
|
2000-02-03 19:54:49 +00:00
|
|
|
#include "unicode/umachine.h"
|
|
|
|
/* include the utfXX.h after the following definitions */
|
|
|
|
|
|
|
|
/* If there is no compiler option for the preferred UTF size, then default to UTF-16. */
|
|
|
|
#ifndef UTF_SIZE
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Number of bits in a Unicode string code unit, same as x in UTF-x (8, 16, or 32). */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_SIZE 16
|
|
|
|
#endif
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Number of bytes in a UChar (sizeof(UChar)). */
|
2000-02-03 19:54:49 +00:00
|
|
|
#define U_SIZEOF_UCHAR (UTF_SIZE>>3)
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/*!
|
|
|
|
* \def U_SIZEOF_WCHAR_T
|
2001-12-07 17:09:41 +00:00
|
|
|
* U_SIZEOF_WCHAR_T==sizeof(wchar_t).
|
2000-12-12 20:31:47 +00:00
|
|
|
*/
|
2000-04-06 22:59:56 +00:00
|
|
|
#ifndef U_HAVE_WCHAR_H
|
|
|
|
# define U_HAVE_WCHAR_H 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* U_SIZEOF_WCHAR_T==sizeof(wchar_t) (0 means it is not defined or autoconf could not set it) */
|
|
|
|
#if U_SIZEOF_WCHAR_T==0
|
2000-04-06 23:37:46 +00:00
|
|
|
# undef U_SIZEOF_WCHAR_T
|
2000-04-06 22:59:56 +00:00
|
|
|
# define U_SIZEOF_WCHAR_T 4
|
2000-02-03 19:54:49 +00:00
|
|
|
#endif
|
|
|
|
|
2001-12-07 17:09:41 +00:00
|
|
|
/*!
|
|
|
|
* \def U_WCHAR_IS_UTF16
|
|
|
|
* Defined if wchar_t uses UTF-16.
|
|
|
|
*/
|
|
|
|
/*!
|
|
|
|
* \def U_WCHAR_IS_UTF32
|
|
|
|
* Defined if wchar_t uses UTF-32.
|
|
|
|
*/
|
|
|
|
#if !defined(U_WCHAR_IS_UTF16) && !defined(U_WCHAR_IS_UTF32)
|
|
|
|
# ifdef __STDC_ISO_10646__
|
|
|
|
# if (U_SIZEOF_WCHAR_T==2)
|
|
|
|
# define U_WCHAR_IS_UTF16
|
|
|
|
# elif (U_SIZEOF_WCHAR_T==4)
|
|
|
|
# define U_WCHAR_IS_UTF32
|
|
|
|
# endif
|
|
|
|
# elif defined __UCS2__
|
|
|
|
# if (__OS390__ || __OS400__) && (U_SIZEOF_WCHAR_T==2)
|
|
|
|
# define U_WCHAR_IS_UTF16
|
|
|
|
# endif
|
|
|
|
# elif defined __UCS4__
|
|
|
|
# if (U_SIZEOF_WCHAR_T==4)
|
|
|
|
# define U_WCHAR_IS_UTF32
|
|
|
|
# endif
|
|
|
|
# elif defined(WIN32) || defined(_WIN32) || defined(WIN64) || defined(_WIN64)
|
|
|
|
# define U_WCHAR_IS_UTF16
|
|
|
|
# endif
|
|
|
|
#endif
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/*!
|
|
|
|
* \var UChar32
|
|
|
|
* Define UChar32 to be wchar_t if that is 32 bits wide; may be signed or unsigned!
|
|
|
|
* If wchar_t is not 32 bits wide, then define UChar32 to be uint32_t.
|
|
|
|
*/
|
2000-02-03 19:54:49 +00:00
|
|
|
#if U_SIZEOF_WCHAR_T==4
|
|
|
|
typedef wchar_t UChar32;
|
|
|
|
#else
|
|
|
|
typedef uint32_t UChar32;
|
|
|
|
#endif
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
|
|
|
* Unicode string and array offset and index type.
|
|
|
|
* ICU always counts Unicode code units (UChars) for string offsets, indexes, and lengths, not Unicode code points.
|
|
|
|
*/
|
2000-02-03 19:54:49 +00:00
|
|
|
typedef int32_t UTextOffset;
|
|
|
|
|
|
|
|
/* Specify which macro versions are the default ones - safe or fast. */
|
|
|
|
#if !defined(UTF_SAFE) && !defined(UTF_STRICT) && !defined(UTF_UNSAFE)
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
|
|
|
* The default choice for general Unicode string macros is to use the ..._SAFE macro implementations
|
|
|
|
* with strict=FALSE. See the utf.h file description.
|
|
|
|
*/
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_SAFE
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* internal definitions ----------------------------------------------------- */
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
2000-12-15 18:22:39 +00:00
|
|
|
* <p>UTF8_ERROR_VALUE_1 and UTF8_ERROR_VALUE_2 are special error values for UTF-8,
|
2000-12-12 20:31:47 +00:00
|
|
|
* which need 1 or 2 bytes in UTF-8:<br>
|
|
|
|
* U+0015 = NAK = Negative Acknowledge, C0 control character<br>
|
|
|
|
* U+009f = highest C1 control character</p>
|
2000-02-03 19:54:49 +00:00
|
|
|
*
|
2000-12-12 20:31:47 +00:00
|
|
|
* <p>These are used by ("safe") UTF-8 macros so that they can return an error value
|
2000-02-03 19:54:49 +00:00
|
|
|
* that needs the same number of code units (bytes) as were seen by
|
2000-12-12 20:31:47 +00:00
|
|
|
* a macro. They should be tested with UTF_IS_ERROR() or UTF_IS_VALID().</p>
|
|
|
|
*
|
|
|
|
* @internal
|
2000-02-03 19:54:49 +00:00
|
|
|
*/
|
|
|
|
#define UTF8_ERROR_VALUE_1 0x15
|
|
|
|
#define UTF8_ERROR_VALUE_2 0x9f
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
|
|
|
* Error value for all UTFs. This code point value will be set by macros with error
|
|
|
|
* checking if an error is detected.
|
|
|
|
*/
|
2000-02-03 19:54:49 +00:00
|
|
|
#define UTF_ERROR_VALUE 0xffff
|
|
|
|
|
|
|
|
/* single-code point definitions -------------------------------------------- */
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Is this code unit or code point a surrogate (U+d800..U+dfff)? */
|
2000-04-13 17:24:48 +00:00
|
|
|
#define UTF_IS_SURROGATE(uchar) (((uchar)&0xfffff800)==0xd800)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2002-02-15 21:08:29 +00:00
|
|
|
/**
|
|
|
|
* Is a given 32-bit code point a Unicode noncharacter?
|
|
|
|
*/
|
|
|
|
#define UTF_IS_UNICODE_NONCHAR(c) \
|
|
|
|
(((((c) & 0xfffe) == 0xfffe) || ((c) >= 0xfdd0 && (c) <= 0xfdef)) && \
|
|
|
|
((c) <= 0x10ffff))
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
2000-02-03 19:54:49 +00:00
|
|
|
* Is a given 32-bit code point/Unicode scalar value
|
|
|
|
* actually a valid Unicode (abstract) character?
|
2001-10-12 18:53:26 +00:00
|
|
|
*
|
2002-02-15 21:08:29 +00:00
|
|
|
* Code points that are not characters include:
|
2001-10-12 18:53:26 +00:00
|
|
|
* - single surrogate code points (U+d800..U+dfff, 2048 code points)
|
|
|
|
* - the last two code points on each plane (U+__fffe and U+__ffff, 34 code points)
|
|
|
|
* - U+fdd0..U+fdef (new with Unicode 3.1, 32 code points)
|
|
|
|
* - the highest Unicode code point value is U+10ffff
|
|
|
|
*
|
|
|
|
* This means that all code points below U+d800 are character code points,
|
|
|
|
* and that boundary is tested first for performance.
|
2000-02-03 19:54:49 +00:00
|
|
|
*/
|
|
|
|
#define UTF_IS_UNICODE_CHAR(c) \
|
2001-10-12 18:53:26 +00:00
|
|
|
((uint32_t)(c)<0xd800 || \
|
|
|
|
((uint32_t)(c)>0xdfff && \
|
|
|
|
(uint32_t)(c)<=0x10ffff && \
|
2002-02-15 21:08:29 +00:00
|
|
|
!UTF_IS_UNICODE_NONCHAR(c)))
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
2000-02-03 19:54:49 +00:00
|
|
|
* Is a given 32-bit code an error value
|
|
|
|
* as returned by one of the macros for any UTF?
|
|
|
|
*/
|
|
|
|
#define UTF_IS_ERROR(c) \
|
|
|
|
(((c)&0xfffe)==0xfffe || (c)==UTF8_ERROR_VALUE_1 || (c)==UTF8_ERROR_VALUE_2)
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/** This is a combined macro: Is c a valid Unicode value _and_ not an error code? */
|
2000-02-03 19:54:49 +00:00
|
|
|
#define UTF_IS_VALID(c) \
|
2001-10-12 18:53:26 +00:00
|
|
|
(UTF_IS_UNICODE_CHAR(c) && \
|
2000-02-03 19:54:49 +00:00
|
|
|
(c)!=UTF8_ERROR_VALUE_1 && (c)!=UTF8_ERROR_VALUE_2)
|
|
|
|
|
|
|
|
/* include the utfXX.h ------------------------------------------------------ */
|
|
|
|
|
|
|
|
#include "unicode/utf8.h"
|
|
|
|
#include "unicode/utf16.h"
|
|
|
|
#include "unicode/utf32.h"
|
|
|
|
|
|
|
|
/* Define types and macros according to the selected UTF size. -------------- */
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/*!
|
|
|
|
* \var UChar
|
|
|
|
* Define UChar to be wchar_t if that is 16 bits wide; always assumed to be unsigned.
|
|
|
|
* If wchar_t is not 16 bits wide, then define UChar to be uint16_t.
|
|
|
|
*/
|
|
|
|
|
2000-02-03 19:54:49 +00:00
|
|
|
#if UTF_SIZE==8
|
|
|
|
|
|
|
|
# error UTF-8 is not implemented, undefine UTF_SIZE or define it to 16
|
|
|
|
|
2000-12-19 23:54:57 +00:00
|
|
|
/*
|
|
|
|
* ANSI C header:
|
|
|
|
* limits.h defines CHAR_MAX
|
|
|
|
*/
|
|
|
|
# include <limits.h>
|
|
|
|
|
2000-04-01 00:17:55 +00:00
|
|
|
/* Define UChar to be compatible with char if possible. */
|
|
|
|
# if CHAR_MAX>=255
|
|
|
|
typedef char UChar;
|
|
|
|
# else
|
|
|
|
typedef uint8_t UChar;
|
|
|
|
# endif
|
2000-02-03 19:54:49 +00:00
|
|
|
|
|
|
|
#elif UTF_SIZE==16
|
|
|
|
|
|
|
|
/* Define UChar to be compatible with wchar_t if possible. */
|
|
|
|
# if U_SIZEOF_WCHAR_T==2
|
|
|
|
typedef wchar_t UChar;
|
|
|
|
# else
|
|
|
|
typedef uint16_t UChar;
|
|
|
|
# endif
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Does this code unit alone encode a code point? */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_IS_SINGLE(uchar) UTF16_IS_SINGLE(uchar)
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Is this code unit the first one of several? */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_IS_LEAD(uchar) UTF16_IS_LEAD(uchar)
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Is this code unit one of several but not the first one? */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_IS_TRAIL(uchar) UTF16_IS_TRAIL(uchar)
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Does this code point require multiple code units? */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_NEED_MULTIPLE_UCHAR(c) UTF16_NEED_MULTIPLE_UCHAR(c)
|
2000-12-12 20:31:47 +00:00
|
|
|
/** How many code units are used to encode this code point? */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_CHAR_LENGTH(c) UTF16_CHAR_LENGTH(c)
|
2000-12-12 20:31:47 +00:00
|
|
|
/** How many code units are used at most for any Unicode code point? */
|
2000-02-09 19:42:15 +00:00
|
|
|
# define UTF_MAX_CHAR_LENGTH UTF16_MAX_CHAR_LENGTH
|
2000-12-12 20:31:47 +00:00
|
|
|
/** Estimate the number of code units for a string based on the number of UTF-16 code units. */
|
2000-02-09 19:42:15 +00:00
|
|
|
# define UTF_ARRAY_SIZE(size) UTF16_ARRAY_SIZE(size)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_GET_CHAR. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_GET_CHAR_UNSAFE(s, i, c) UTF16_GET_CHAR_UNSAFE(s, i, c)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_GET_CHAR. */
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_GET_CHAR_SAFE(s, start, i, length, c, strict) UTF16_GET_CHAR_SAFE(s, start, i, length, c, strict)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_NEXT_CHAR. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_NEXT_CHAR_UNSAFE(s, i, c) UTF16_NEXT_CHAR_UNSAFE(s, i, c)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_NEXT_CHAR. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_NEXT_CHAR_SAFE(s, i, length, c, strict) UTF16_NEXT_CHAR_SAFE(s, i, length, c, strict)
|
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_APPEND_CHAR. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_APPEND_CHAR_UNSAFE(s, i, c) UTF16_APPEND_CHAR_UNSAFE(s, i, c)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_APPEND_CHAR. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_APPEND_CHAR_SAFE(s, i, length, c) UTF16_APPEND_CHAR_SAFE(s, i, length, c)
|
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_FWD_1. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_FWD_1_UNSAFE(s, i) UTF16_FWD_1_UNSAFE(s, i)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_FWD_1. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_FWD_1_SAFE(s, i, length) UTF16_FWD_1_SAFE(s, i, length)
|
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_FWD_N. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_FWD_N_UNSAFE(s, i, n) UTF16_FWD_N_UNSAFE(s, i, n)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_FWD_N. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_FWD_N_SAFE(s, i, length, n) UTF16_FWD_N_SAFE(s, i, length, n)
|
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_SET_CHAR_START. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_SET_CHAR_START_UNSAFE(s, i) UTF16_SET_CHAR_START_UNSAFE(s, i)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_SET_CHAR_START. */
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_SET_CHAR_START_SAFE(s, start, i) UTF16_SET_CHAR_START_SAFE(s, start, i)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_PREV_CHAR. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_PREV_CHAR_UNSAFE(s, i, c) UTF16_PREV_CHAR_UNSAFE(s, i, c)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_PREV_CHAR. */
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_PREV_CHAR_SAFE(s, start, i, c, strict) UTF16_PREV_CHAR_SAFE(s, start, i, c, strict)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_BACK_1. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_BACK_1_UNSAFE(s, i) UTF16_BACK_1_UNSAFE(s, i)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_BACK_1. */
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_BACK_1_SAFE(s, start, i) UTF16_BACK_1_SAFE(s, start, i)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_BACK_N. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_BACK_N_UNSAFE(s, i, n) UTF16_BACK_N_UNSAFE(s, i, n)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_BACK_N. */
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_BACK_N_SAFE(s, start, i, n) UTF16_BACK_N_SAFE(s, start, i, n)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_SET_CHAR_LIMIT. */
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_SET_CHAR_LIMIT_UNSAFE(s, i) UTF16_SET_CHAR_LIMIT_UNSAFE(s, i)
|
2000-12-15 18:22:39 +00:00
|
|
|
/** See file documentation and UTF_SET_CHAR_LIMIT. */
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_SET_CHAR_LIMIT_SAFE(s, start, i, length) UTF16_SET_CHAR_LIMIT_SAFE(s, start, i, length)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
|
|
|
#elif UTF_SIZE==32
|
|
|
|
|
|
|
|
# error UTF-32 is not implemented, undefine UTF_SIZE or define it to 16
|
|
|
|
|
|
|
|
typedef UChar32 UChar;
|
|
|
|
|
|
|
|
#else
|
|
|
|
# error UTF_SIZE must be undefined or one of { 8, 16, 32 } - only 16 is implemented
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Define the default macros for handling UTF characters. ------------------- */
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
/**
|
|
|
|
* \def UTF_GET_CHAR(s, start, i, length, c)
|
|
|
|
*
|
|
|
|
* Set c to the code point that contains the code unit i.
|
|
|
|
* i could point to the first, the last, or an intermediate code unit.
|
|
|
|
* i is not modified.
|
|
|
|
* \pre 0<=i<length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_NEXT_CHAR(s, i, length, c)
|
|
|
|
*
|
|
|
|
* Set c to the code point that starts at code unit i
|
|
|
|
* and advance i to beyond the code units of this code point (post-increment).
|
2000-12-14 18:36:44 +00:00
|
|
|
* i must point to the first code unit of a code point.
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre 0<=i<length
|
|
|
|
* \post 0<i<=length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_APPEND_CHAR(s, i, length, c)
|
|
|
|
*
|
|
|
|
* Append the code units of code point c to the string at index i
|
|
|
|
* and advance i to beyond the new code units (post-increment).
|
2000-12-14 18:36:44 +00:00
|
|
|
* The code units beginning at index i will be overwritten.
|
2000-12-15 18:22:39 +00:00
|
|
|
* \pre 0<=c<=0x10ffff
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre 0<=i<length
|
|
|
|
* \post 0<i<=length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_FWD_1(s, i, length)
|
|
|
|
*
|
|
|
|
* Advance i to beyond the code units of the code point that begins at i.
|
|
|
|
* I.e., advance i by one code point.
|
2000-12-14 18:36:44 +00:00
|
|
|
* i must point to the first code unit of a code point.
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre 0<=i<length
|
|
|
|
* \post 0<i<=length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_FWD_N(s, i, length, n)
|
|
|
|
*
|
|
|
|
* Advance i to beyond the code units of the n code points where the first one begins at i.
|
|
|
|
* I.e., advance i by n code points.
|
2000-12-14 18:36:44 +00:00
|
|
|
* i must point to the first code unit of a code point.
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre 0<=i<length
|
|
|
|
* \post 0<i<=length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_SET_CHAR_START(s, start, i)
|
|
|
|
*
|
|
|
|
* Take the random-access index i and adjust it so that it points to the beginning
|
|
|
|
* of a code point.
|
|
|
|
* The input index points to any code unit of a code point and is moved to point to
|
|
|
|
* the first code unit of the same code point. i is never incremented.
|
2000-12-14 18:36:44 +00:00
|
|
|
* This can be used to start an iteration with UTF_NEXT_CHAR() from a random index.
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre start<=i<length
|
|
|
|
* \post start<=i<length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_PREV_CHAR(s, start, i, c)
|
|
|
|
*
|
|
|
|
* Set c to the code point that has code units before i
|
2000-12-14 18:36:44 +00:00
|
|
|
* and move i backward (towards the beginning of the string)
|
|
|
|
* to the first code unit of this code point (pre-increment).
|
|
|
|
* i must point to the first code unit after the last unit of a code point (i==length is allowed).
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre start<i<=length
|
|
|
|
* \post start<=i<length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_BACK_1(s, start, i)
|
|
|
|
*
|
2000-12-14 18:36:44 +00:00
|
|
|
* Move i backward (towards the beginning of the string)
|
|
|
|
* to the first code unit of the code point that has code units before i.
|
|
|
|
* I.e., move i backward by one code point.
|
|
|
|
* i must point to the first code unit after the last unit of a code point (i==length is allowed).
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre start<i<=length
|
|
|
|
* \post start<=i<length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_BACK_N(s, start, i, n)
|
|
|
|
*
|
2000-12-14 18:36:44 +00:00
|
|
|
* Move i backward (towards the beginning of the string)
|
|
|
|
* to the first code unit of the n code points that have code units before i.
|
|
|
|
* I.e., move i backward by n code points.
|
|
|
|
* i must point to the first code unit after the last unit of a code point (i==length is allowed).
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre start<i<=length
|
|
|
|
* \post start<=i<length
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \def UTF_SET_CHAR_LIMIT(s, start, i, length)
|
|
|
|
*
|
2000-12-14 18:36:44 +00:00
|
|
|
* Take the random-access index i and adjust it so that it points beyond
|
2000-12-12 20:31:47 +00:00
|
|
|
* a code point. The input index points beyond any code unit
|
|
|
|
* of a code point and is moved to point beyond the last code unit of the same
|
|
|
|
* code point. i is never decremented.
|
2000-12-14 18:36:44 +00:00
|
|
|
* This can be used to start an iteration with UTF_PREV_CHAR() from a random index.
|
2000-12-12 20:31:47 +00:00
|
|
|
* \pre start<i<=length
|
|
|
|
* \post start<i<=length
|
|
|
|
*/
|
|
|
|
|
2000-02-03 19:54:49 +00:00
|
|
|
#ifdef UTF_SAFE
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
# define UTF_GET_CHAR(s, start, i, length, c) UTF_GET_CHAR_SAFE(s, start, i, length, c, FALSE)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
# define UTF_NEXT_CHAR(s, i, length, c) UTF_NEXT_CHAR_SAFE(s, i, length, c, FALSE)
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_APPEND_CHAR(s, i, length, c) UTF_APPEND_CHAR_SAFE(s, i, length, c)
|
|
|
|
# define UTF_FWD_1(s, i, length) UTF_FWD_1_SAFE(s, i, length)
|
|
|
|
# define UTF_FWD_N(s, i, length, n) UTF_FWD_N_SAFE(s, i, length, n)
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_SET_CHAR_START(s, start, i) UTF_SET_CHAR_START_SAFE(s, start, i)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
# define UTF_PREV_CHAR(s, start, i, c) UTF_PREV_CHAR_SAFE(s, start, i, c, FALSE)
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_BACK_1(s, start, i) UTF_BACK_1_SAFE(s, start, i)
|
|
|
|
# define UTF_BACK_N(s, start, i, n) UTF_BACK_N_SAFE(s, start, i, n)
|
|
|
|
# define UTF_SET_CHAR_LIMIT(s, start, i, length) UTF_SET_CHAR_LIMIT_SAFE(s, start, i, length)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
|
|
|
#elif defined(UTF_STRICT)
|
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
# define UTF_GET_CHAR(s, start, i, length, c) UTF_GET_CHAR_SAFE(s, start, i, length, c, TRUE)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
# define UTF_NEXT_CHAR(s, i, length, c) UTF_NEXT_CHAR_SAFE(s, i, length, c, TRUE)
|
2000-02-03 19:54:49 +00:00
|
|
|
# define UTF_APPEND_CHAR(s, i, length, c) UTF_APPEND_CHAR_SAFE(s, i, length, c)
|
|
|
|
# define UTF_FWD_1(s, i, length) UTF_FWD_1_SAFE(s, i, length)
|
|
|
|
# define UTF_FWD_N(s, i, length, n) UTF_FWD_N_SAFE(s, i, length, n)
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_SET_CHAR_START(s, start, i) UTF_SET_CHAR_START_SAFE(s, start, i)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-12-12 20:31:47 +00:00
|
|
|
# define UTF_PREV_CHAR(s, start, i, c) UTF_PREV_CHAR_SAFE(s, start, i, c, TRUE)
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_BACK_1(s, start, i) UTF_BACK_1_SAFE(s, start, i)
|
|
|
|
# define UTF_BACK_N(s, start, i, n) UTF_BACK_N_SAFE(s, start, i, n)
|
|
|
|
# define UTF_SET_CHAR_LIMIT(s, start, i, length) UTF_SET_CHAR_LIMIT_SAFE(s, start, i, length)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
|
|
|
#else /* UTF_UNSAFE */
|
|
|
|
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_GET_CHAR(s, start, i, length, c) UTF_GET_CHAR_UNSAFE(s, i, c)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
|
|
|
# define UTF_NEXT_CHAR(s, i, length, c) UTF_NEXT_CHAR_UNSAFE(s, i, c)
|
|
|
|
# define UTF_APPEND_CHAR(s, i, length, c) UTF_APPEND_CHAR_UNSAFE(s, i, c)
|
|
|
|
# define UTF_FWD_1(s, i, length) UTF_FWD_1_UNSAFE(s, i)
|
|
|
|
# define UTF_FWD_N(s, i, length, n) UTF_FWD_N_UNSAFE(s, i, n)
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_SET_CHAR_START(s, start, i) UTF_SET_CHAR_START_UNSAFE(s, i)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
2000-04-12 19:36:07 +00:00
|
|
|
# define UTF_PREV_CHAR(s, start, i, c) UTF_PREV_CHAR_UNSAFE(s, i, c)
|
|
|
|
# define UTF_BACK_1(s, start, i) UTF_BACK_1_UNSAFE(s, i)
|
|
|
|
# define UTF_BACK_N(s, start, i, n) UTF_BACK_N_UNSAFE(s, i, n)
|
|
|
|
# define UTF_SET_CHAR_LIMIT(s, start, i, length) UTF_SET_CHAR_LIMIT_UNSAFE(s, i)
|
2000-02-03 19:54:49 +00:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|