2000-06-27 16:30:16 +00:00
|
|
|
/*
|
2001-03-21 20:44:20 +00:00
|
|
|
******************************************************************************
|
|
|
|
* Copyright (C) 1997-2001, International Business Machines
|
2000-06-27 16:30:16 +00:00
|
|
|
* Corporation and others. All Rights Reserved.
|
2001-03-21 20:44:20 +00:00
|
|
|
******************************************************************************
|
2000-06-27 16:30:16 +00:00
|
|
|
* Date Name Description
|
|
|
|
* 06/23/00 aliu Creation.
|
2001-03-21 20:44:20 +00:00
|
|
|
******************************************************************************
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
|
2001-03-01 23:55:41 +00:00
|
|
|
#ifndef __UREP_H
|
|
|
|
#define __UREP_H
|
2000-06-27 16:30:16 +00:00
|
|
|
|
|
|
|
#include "unicode/utypes.h"
|
|
|
|
|
2001-03-01 23:55:41 +00:00
|
|
|
U_CDECL_BEGIN
|
|
|
|
|
2000-06-27 16:30:16 +00:00
|
|
|
/********************************************************************
|
|
|
|
* General Notes
|
|
|
|
********************************************************************
|
|
|
|
* TODO
|
|
|
|
* Add usage scenario
|
|
|
|
* Add test code
|
|
|
|
* Talk about pinning
|
|
|
|
* Talk about "can truncate result if out of memory"
|
|
|
|
*/
|
|
|
|
|
|
|
|
/********************************************************************
|
|
|
|
* Data Structures
|
|
|
|
********************************************************************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An opaque replaceable text object. This will be manipulated only
|
|
|
|
* through the caller-supplied UReplaceableFunctor struct. Related
|
|
|
|
* to the C++ class Replaceable.
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
typedef void* UReplaceable;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A set of function pointers that transliterators use to manipulate a
|
|
|
|
* UReplaceable. The caller should supply the required functions to
|
|
|
|
* manipulate their text appropriately. Related to the C++ class
|
|
|
|
* Replaceable.
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
2002-08-23 15:49:09 +00:00
|
|
|
typedef struct UReplaceableCallbacks {
|
2000-06-27 16:30:16 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Function pointer that returns the number of UChar code units in
|
|
|
|
* this text.
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
int32_t (*length)(const UReplaceable* rep);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function pointer that returns a UChar code units at the given
|
|
|
|
* offset into this text; 0 <= offset < n, where n is the value
|
|
|
|
* returned by (*length)(rep). See unistr.h for a description of
|
|
|
|
* charAt() vs. char32At().
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
UChar (*charAt)(const UReplaceable* rep,
|
|
|
|
int32_t offset);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function pointer that returns a UChar32 code point at the given
|
|
|
|
* offset into this text. See unistr.h for a description of
|
|
|
|
* charAt() vs. char32At().
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
UChar32 (*char32At)(const UReplaceable* rep,
|
|
|
|
int32_t offset);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Function pointer that replaces text between start and limit in
|
|
|
|
* this text with the given text. Attributes (out of band info)
|
|
|
|
* should be retained.
|
|
|
|
* @param start the starting index of the text to be replaced,
|
|
|
|
* inclusive.
|
|
|
|
* @param limit the ending index of the text to be replaced,
|
|
|
|
* exclusive.
|
|
|
|
* @param text the new text to replace the UChars from
|
|
|
|
* start..limit-1.
|
|
|
|
* @param textLength the number of UChars at text, or -1 if text
|
|
|
|
* is null-terminated.
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
void (*replace)(UReplaceable* rep,
|
|
|
|
int32_t start,
|
|
|
|
int32_t limit,
|
|
|
|
const UChar* text,
|
|
|
|
int32_t textLength);
|
|
|
|
|
2002-02-26 17:50:59 +00:00
|
|
|
/**
|
|
|
|
* Function pointer that copies the characters in the range
|
|
|
|
* [<tt>start</tt>, <tt>limit</tt>) into the array <tt>dst</tt>.
|
|
|
|
* @param start offset of first character which will be copied
|
|
|
|
* into the array
|
|
|
|
* @param limit offset immediately following the last character to
|
|
|
|
* be copied
|
|
|
|
* @param dst array in which to copy characters. The length of
|
|
|
|
* <tt>dst</tt> must be at least <tt>(limit - start)</tt>.
|
|
|
|
* @draft ICU 2.1
|
|
|
|
*/
|
|
|
|
void (*extract)(UReplaceable* rep,
|
|
|
|
int32_t start,
|
|
|
|
int32_t limit,
|
|
|
|
UChar* dst);
|
|
|
|
|
2000-06-27 16:30:16 +00:00
|
|
|
/**
|
|
|
|
* Function pointer that copies text between start and limit in
|
|
|
|
* this text to another index in the text. Attributes (out of
|
|
|
|
* band info) should be retained. After this call, there will be
|
|
|
|
* (at least) two copies of the characters originally located at
|
|
|
|
* start..limit-1.
|
|
|
|
* @param start the starting index of the text to be copied,
|
|
|
|
* inclusive.
|
|
|
|
* @param limit the ending index of the text to be copied,
|
|
|
|
* exclusive.
|
|
|
|
* @param dest the index at which the copy of the UChars should be
|
|
|
|
* inserted.
|
2001-11-13 22:47:47 +00:00
|
|
|
* @stable
|
2000-06-27 16:30:16 +00:00
|
|
|
*/
|
|
|
|
void (*copy)(UReplaceable* rep,
|
|
|
|
int32_t start,
|
|
|
|
int32_t limit,
|
|
|
|
int32_t dest);
|
|
|
|
|
|
|
|
} UReplaceableCallbacks;
|
|
|
|
|
2001-03-01 23:55:41 +00:00
|
|
|
U_CDECL_END
|
|
|
|
|
2000-06-27 16:30:16 +00:00
|
|
|
#endif
|