blob: 5195193633366ed9b5284a6ba83c642fb50abceb [file] [log] [blame]
/*
******************************************************************************
*
* Copyright (C) 1999-2001, International Business Machines
* Corporation and others. All Rights Reserved.
*
******************************************************************************
* file name: ubidi.h
* encoding: US-ASCII
* tab size: 8 (not used)
* indentation:4
*
* created on: 1999sep15
* created by: Markus W. Scherer
*/
#ifndef BIDI_H
#define BIDI_H
#include "unicode/utypes.h"
#include "unicode/uobject.h"
#include "unicode/ubidi.h"
#ifdef ICU_UBIDI_USE_DEPRECATES
#ifndef XP_CPLUSPLUS
# error This is a C++ header file.
#endif
U_NAMESPACE_BEGIN
/**
* This class is obsolete and will be removed.
* Use the C API with the UBiDi type and ubidi_... functions.
* The BiDi class was just a pure 1:1 wrapper for the ubidi_ API.
*
* Old documentation:
*
* BiDi is a C++ wrapper class for UBiDi.
* You need one BiDi object in place of one UBiDi object.
* For details on the API and implementation of the
* Unicode BiDi algorithm, see ubidi.h.
*
* @see UBiDi
* @obsolete ICU 2.4. Use the C API with UBiDi and ubidi_... functions instead since this API will be removed in that release.
*/
class U_COMMON_API BiDi : public UObject {
public:
/** @memo Default constructor, calls ubidi_open().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
BiDi();
/** @memo Constructor, calls ubidi_open().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
BiDi(UErrorCode &rErrorCode);
/** @memo Preallocating constructor, calls ubidi_openSized().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
BiDi(int32_t maxLength, int32_t maxRunCount, UErrorCode &rErrorCode);
/** @memo Destructor, calls ubidi_close().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
~BiDi();
/**
* Modify the operation of the BiDi algorithm such that it
* approximates an "inverse BiDi" algorithm. This function
* must be called before <code>setPara()</code>.
*
* @param isInverse specifies "forward" or "inverse" BiDi operation
*
* @see setPara
* @see writeReordered
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
void
setInverse(UBool isInverse);
/**
* Is this BiDi object set to perform the inverse BiDi algorithm?
*
* @see setInverse
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
UBool
isInverse();
/** @memo Set this object for one paragraph's text.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
BiDi &
setPara(const UChar *text, int32_t length,
UBiDiLevel paraLevel, UBiDiLevel *embeddingLevels,
UErrorCode &rErrorCode);
/** @memo Set this object for one line of the paragraph object's text.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
BiDi &
setLine(const BiDi &rParaBiDi,
int32_t start, int32_t limit,
UErrorCode &rErrorCode);
/** @memo Get the directionality of the text.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
UBiDiDirection
getDirection() const;
/** @memo Get the pointer to the text.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
const UChar *
getText() const;
/** @memo Get the length of the text.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
int32_t
getLength() const;
/** @memo Get the paragraph level of the text.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
UBiDiLevel
getParaLevel() const;
/** @memo Get the level for one character.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
UBiDiLevel
getLevelAt(int32_t charIndex) const;
/** @memo Get an array of levels for each character.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
const UBiDiLevel *
getLevels(UErrorCode &rErrorCode);
/** @memo Get a logical run.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
void
getLogicalRun(int32_t logicalStart,
int32_t &rLogicalLimit, UBiDiLevel &rLevel) const;
/** @memo Get the number of runs.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
int32_t
countRuns(UErrorCode &rErrorCode);
/**
* @memo Get one run's logical start, length, and directionality,
* which can be 0 for LTR or 1 for RTL.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
UBiDiDirection
getVisualRun(int32_t runIndex, int32_t &rLogicalStart, int32_t &rLength);
/** @memo Get the visual position from a logical text position.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
int32_t
getVisualIndex(int32_t logicalIndex, UErrorCode &rErrorCode);
/** @memo Get the logical text position from a visual position.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
int32_t
getLogicalIndex(int32_t visualIndex, UErrorCode &rErrorCode);
/**
* @memo Get a logical-to-visual index map (array) for the characters in the UBiDi
* (paragraph or line) object.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
void
getLogicalMap(int32_t *indexMap, UErrorCode &rErrorCode);
/**
* @memo Get a visual-to-logical index map (array) for the characters in the UBiDi
* (paragraph or line) object.
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
void
getVisualMap(int32_t *indexMap, UErrorCode &rErrorCode);
/** @memo Same as ubidi_reorderLogical().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
static void
reorderLogical(const UBiDiLevel *levels, int32_t length, int32_t *indexMap);
/** @memo Same as ubidi_reorderVisual().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
static void
reorderVisual(const UBiDiLevel *levels, int32_t length, int32_t *indexMap);
/** @memo Same as ubidi_invertMap().
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
static void
invertMap(const int32_t *srcMap, int32_t *destMap, int32_t length);
/**
* Use the <code>BiDi</code> object containing the reordering
* information for one paragraph or line of text as set by
* <code>setPara()</code> or <code>setLine()</code> and
* write a reordered string to the destination buffer.
*
* @see ubidi_writeReordered
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
int32_t
writeReordered(UChar *dest, int32_t destSize,
uint16_t options,
UErrorCode &rErrorCode);
/**
* Reverse a Right-To-Left run of Unicode text.
*
* @see ubidi_writeReverse
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
static int32_t
writeReverse(const UChar *src, int32_t srcLength,
UChar *dest, int32_t destSize,
uint16_t options,
UErrorCode &rErrorCode);
/**
* ICU "poor man's RTTI", returns a UClassID for the actual class.
*
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
virtual inline UClassID getDynamicClassID() const { return getStaticClassID(); }
/**
* ICU "poor man's RTTI", returns a UClassID for this class.
*
* @obsolete ICU 2.4. Use the parallel ubidi_ C API instead since this API will be removed in that release.
*/
static inline UClassID getStaticClassID() { return (UClassID)&fgClassID; }
protected:
UBiDi *pBiDi;
private:
/**
* The address of this static class variable serves as this class's ID
* for ICU "poor man's RTTI".
*/
static const char fgClassID;
};
/* Inline implementations. -------------------------------------------------- */
inline BiDi::BiDi() {
pBiDi=ubidi_open();
}
inline BiDi::BiDi(UErrorCode &rErrorCode) {
if(U_SUCCESS(rErrorCode)) {
pBiDi=ubidi_open();
if(pBiDi==0) {
rErrorCode=U_MEMORY_ALLOCATION_ERROR;
}
} else {
pBiDi=0;
}
}
inline BiDi::BiDi(int32_t maxLength, int32_t maxRunCount, UErrorCode &rErrorCode) {
pBiDi=ubidi_openSized(maxLength, maxRunCount, &rErrorCode);
}
inline BiDi::~BiDi() {
ubidi_close(pBiDi);
pBiDi=0;
}
inline void
BiDi::setInverse(UBool isInverse) {
ubidi_setInverse(pBiDi, isInverse);
}
inline UBool
BiDi::isInverse() {
return ubidi_isInverse(pBiDi);
}
inline BiDi &
BiDi::setPara(const UChar *text, int32_t length,
UBiDiLevel paraLevel, UBiDiLevel *embeddingLevels,
UErrorCode &rErrorCode) {
ubidi_setPara(pBiDi, text, length, paraLevel, embeddingLevels, &rErrorCode);
return *this;
}
inline BiDi &
BiDi::setLine(const BiDi &rParaBiDi,
int32_t start, int32_t limit,
UErrorCode &rErrorCode) {
ubidi_setLine(rParaBiDi.pBiDi, start, limit, pBiDi, &rErrorCode);
return *this;
}
inline UBiDiDirection
BiDi::getDirection() const {
return ubidi_getDirection(pBiDi);
}
inline const UChar *
BiDi::getText() const {
return ubidi_getText(pBiDi);
}
inline int32_t
BiDi::getLength() const {
return ubidi_getLength(pBiDi);
}
inline UBiDiLevel
BiDi::getParaLevel() const {
return ubidi_getParaLevel(pBiDi);
}
inline UBiDiLevel
BiDi::getLevelAt(int32_t charIndex) const {
return ubidi_getLevelAt(pBiDi, charIndex);
}
inline const UBiDiLevel *
BiDi::getLevels(UErrorCode &rErrorCode) {
return ubidi_getLevels(pBiDi, &rErrorCode);
}
inline void
BiDi::getLogicalRun(int32_t logicalStart,
int32_t &rLogicalLimit, UBiDiLevel &rLevel) const {
ubidi_getLogicalRun(pBiDi, logicalStart, &rLogicalLimit, &rLevel);
}
inline int32_t
BiDi::countRuns(UErrorCode &rErrorCode) {
return ubidi_countRuns(pBiDi, &rErrorCode);
}
inline UBiDiDirection
BiDi::getVisualRun(int32_t runIndex, int32_t &rLogicalStart, int32_t &rLength) {
return ubidi_getVisualRun(pBiDi, runIndex, &rLogicalStart, &rLength);
}
inline int32_t
BiDi::getVisualIndex(int32_t logicalIndex, UErrorCode &rErrorCode) {
return ubidi_getVisualIndex(pBiDi, logicalIndex, &rErrorCode);
}
inline int32_t
BiDi::getLogicalIndex(int32_t visualIndex, UErrorCode &rErrorCode) {
return ubidi_getLogicalIndex(pBiDi, visualIndex, &rErrorCode);
}
inline void
BiDi::getLogicalMap(int32_t *indexMap, UErrorCode &rErrorCode) {
ubidi_getLogicalMap(pBiDi, indexMap, &rErrorCode);
}
inline void
BiDi::getVisualMap(int32_t *indexMap, UErrorCode &rErrorCode) {
ubidi_getVisualMap(pBiDi, indexMap, &rErrorCode);
}
inline void
BiDi::reorderLogical(const UBiDiLevel *levels, int32_t length, int32_t *indexMap) {
ubidi_reorderLogical(levels, length, indexMap);
}
inline void
BiDi::reorderVisual(const UBiDiLevel *levels, int32_t length, int32_t *indexMap) {
ubidi_reorderVisual(levels, length, indexMap);
}
inline void
BiDi::invertMap(const int32_t *srcMap, int32_t *destMap, int32_t length) {
ubidi_invertMap(srcMap, destMap, length);
}
inline int32_t
BiDi::writeReordered(UChar *dest, int32_t destSize,
uint16_t options,
UErrorCode &rErrorCode) {
return ubidi_writeReordered(pBiDi, dest, destSize, options, &rErrorCode);
}
inline int32_t
BiDi::writeReverse(const UChar *src, int32_t srcLength,
UChar *dest, int32_t destSize,
uint16_t options,
UErrorCode &rErrorCode) {
return ubidi_writeReverse(src, srcLength, dest, destSize, options, &rErrorCode);
}
U_NAMESPACE_END
#else
#error "The unicode/bidi.h header is obsolete. Please use the BiDi C API in unicode/ubidi.h instead."
#endif /* ICU_UBIDI_USE_DEPRECATES */
#endif