ICU 57.1 57.1
ubidi.h
Go to the documentation of this file.
1/*
2******************************************************************************
3*
4* Copyright (C) 1999-2013, International Business Machines
5* Corporation and others. All Rights Reserved.
6*
7******************************************************************************
8* file name: ubidi.h
9* encoding: US-ASCII
10* tab size: 8 (not used)
11* indentation:4
12*
13* created on: 1999jul27
14* created by: Markus W. Scherer, updated by Matitiahu Allouche
15*/
16
17#ifndef UBIDI_H
18#define UBIDI_H
19
20#include "unicode/utypes.h"
21#include "unicode/uchar.h"
23
287/*DOCXX_TAG*/
330typedef uint8_t UBiDiLevel;
331
356#define UBIDI_DEFAULT_LTR 0xfe
357
383#define UBIDI_DEFAULT_RTL 0xff
384
390#define UBIDI_MAX_EXPLICIT_LEVEL 125
391
396#define UBIDI_LEVEL_OVERRIDE 0x80
397
411#define UBIDI_MAP_NOWHERE (-1)
412
457
460
471struct UBiDi;
472
474typedef struct UBiDi UBiDi;
475
491U_STABLE UBiDi * U_EXPORT2
493
528U_STABLE UBiDi * U_EXPORT2
529ubidi_openSized(int32_t maxLength, int32_t maxRunCount, UErrorCode *pErrorCode);
530
551U_STABLE void U_EXPORT2
553
554#if U_SHOW_CPLUSPLUS_API
555
557
568
570
571#endif
572
621U_STABLE void U_EXPORT2
622ubidi_setInverse(UBiDi *pBiDi, UBool isInverse);
623
640U_STABLE UBool U_EXPORT2
642
663U_STABLE void U_EXPORT2
664ubidi_orderParagraphsLTR(UBiDi *pBiDi, UBool orderParagraphsLTR);
665
677U_STABLE UBool U_EXPORT2
679
725
877U_STABLE void U_EXPORT2
879
890
906
952
970
1019
1033U_STABLE void U_EXPORT2
1034ubidi_setReorderingOptions(UBiDi *pBiDi, uint32_t reorderingOptions);
1035
1044U_STABLE uint32_t U_EXPORT2
1046
1131U_STABLE void U_EXPORT2
1133 const UChar *prologue, int32_t proLength,
1134 const UChar *epilogue, int32_t epiLength,
1135 UErrorCode *pErrorCode);
1136
1216U_STABLE void U_EXPORT2
1217ubidi_setPara(UBiDi *pBiDi, const UChar *text, int32_t length,
1218 UBiDiLevel paraLevel, UBiDiLevel *embeddingLevels,
1219 UErrorCode *pErrorCode);
1220
1267U_STABLE void U_EXPORT2
1268ubidi_setLine(const UBiDi *pParaBiDi,
1269 int32_t start, int32_t limit,
1270 UBiDi *pLineBiDi,
1271 UErrorCode *pErrorCode);
1272
1288U_STABLE UBiDiDirection U_EXPORT2
1290
1318U_STABLE UBiDiDirection U_EXPORT2
1319ubidi_getBaseDirection(const UChar *text, int32_t length );
1320
1332U_STABLE const UChar * U_EXPORT2
1333ubidi_getText(const UBiDi *pBiDi);
1334
1343U_STABLE int32_t U_EXPORT2
1345
1361U_STABLE UBiDiLevel U_EXPORT2
1363
1372U_STABLE int32_t U_EXPORT2
1374
1409U_STABLE int32_t U_EXPORT2
1410ubidi_getParagraph(const UBiDi *pBiDi, int32_t charIndex, int32_t *pParaStart,
1411 int32_t *pParaLimit, UBiDiLevel *pParaLevel,
1412 UErrorCode *pErrorCode);
1413
1441U_STABLE void U_EXPORT2
1442ubidi_getParagraphByIndex(const UBiDi *pBiDi, int32_t paraIndex,
1443 int32_t *pParaStart, int32_t *pParaLimit,
1444 UBiDiLevel *pParaLevel, UErrorCode *pErrorCode);
1445
1461U_STABLE UBiDiLevel U_EXPORT2
1462ubidi_getLevelAt(const UBiDi *pBiDi, int32_t charIndex);
1463
1482U_STABLE const UBiDiLevel * U_EXPORT2
1483ubidi_getLevels(UBiDi *pBiDi, UErrorCode *pErrorCode);
1484
1509U_STABLE void U_EXPORT2
1510ubidi_getLogicalRun(const UBiDi *pBiDi, int32_t logicalPosition,
1511 int32_t *pLogicalLimit, UBiDiLevel *pLevel);
1512
1528U_STABLE int32_t U_EXPORT2
1529ubidi_countRuns(UBiDi *pBiDi, UErrorCode *pErrorCode);
1530
1587U_STABLE UBiDiDirection U_EXPORT2
1588ubidi_getVisualRun(UBiDi *pBiDi, int32_t runIndex,
1589 int32_t *pLogicalStart, int32_t *pLength);
1590
1628U_STABLE int32_t U_EXPORT2
1629ubidi_getVisualIndex(UBiDi *pBiDi, int32_t logicalIndex, UErrorCode *pErrorCode);
1630
1663U_STABLE int32_t U_EXPORT2
1664ubidi_getLogicalIndex(UBiDi *pBiDi, int32_t visualIndex, UErrorCode *pErrorCode);
1665
1706U_STABLE void U_EXPORT2
1707ubidi_getLogicalMap(UBiDi *pBiDi, int32_t *indexMap, UErrorCode *pErrorCode);
1708
1742U_STABLE void U_EXPORT2
1743ubidi_getVisualMap(UBiDi *pBiDi, int32_t *indexMap, UErrorCode *pErrorCode);
1744
1765U_STABLE void U_EXPORT2
1766ubidi_reorderLogical(const UBiDiLevel *levels, int32_t length, int32_t *indexMap);
1767
1788U_STABLE void U_EXPORT2
1789ubidi_reorderVisual(const UBiDiLevel *levels, int32_t length, int32_t *indexMap);
1790
1823U_STABLE void U_EXPORT2
1824ubidi_invertMap(const int32_t *srcMap, int32_t *destMap, int32_t length);
1825
1835#define UBIDI_KEEP_BASE_COMBINING 1
1836
1845#define UBIDI_DO_MIRRORING 2
1846
1859#define UBIDI_INSERT_LRM_FOR_NUMERIC 4
1860
1872#define UBIDI_REMOVE_BIDI_CONTROLS 8
1873
1888#define UBIDI_OUTPUT_REVERSE 16
1889
1928U_STABLE int32_t U_EXPORT2
1930
1958U_STABLE int32_t U_EXPORT2
1960
1968#define U_BIDI_CLASS_DEFAULT U_CHAR_DIRECTION_COUNT
1969
1991UBiDiClassCallback(const void *context, UChar32 c);
1992
1994
2010U_STABLE UCharDirection U_EXPORT2
2012
2040U_STABLE void U_EXPORT2
2042 const void *newContext, UBiDiClassCallback **oldFn,
2043 const void **oldContext, UErrorCode *pErrorCode);
2044
2057U_STABLE void U_EXPORT2
2058ubidi_getClassCallback(UBiDi *pBiDi, UBiDiClassCallback **fn, const void **context);
2059
2125U_STABLE int32_t U_EXPORT2
2127 UChar *dest, int32_t destSize,
2128 uint16_t options,
2129 UErrorCode *pErrorCode);
2130
2177U_STABLE int32_t U_EXPORT2
2178ubidi_writeReverse(const UChar *src, int32_t srcLength,
2179 UChar *dest, int32_t destSize,
2180 uint16_t options,
2181 UErrorCode *pErrorCode);
2182
2183/*#define BIDI_SAMPLE_CODE*/
2186#endif
"Smart pointer" class, closes a UBiDi via ubidi_close().
C++ API: "Smart pointers" for use with and in ICU4C C++ code.
#define U_DEFINE_LOCAL_OPEN_POINTER(LocalPointerClassName, Type, closeFunction)
"Smart pointer" definition macro, deletes objects via the closeFunction.
Definition: localpointer.h:539
#define U_CALLCONV
Similar to U_CDECL_BEGIN/U_CDECL_END, this qualifier is necessary in callback function typedefs to ma...
Definition: platform.h:849
void ubidi_reorderVisual(const UBiDiLevel *levels, int32_t length, int32_t *indexMap)
This is a convenience function that does not use a UBiDi object.
void ubidi_getClassCallback(UBiDi *pBiDi, UBiDiClassCallback **fn, const void **context)
Get the current callback function used for Bidi class determination.
int32_t ubidi_getVisualIndex(UBiDi *pBiDi, int32_t logicalIndex, UErrorCode *pErrorCode)
Get the visual position from a logical text position.
const UChar * ubidi_getText(const UBiDi *pBiDi)
Get the pointer to the text.
void ubidi_reorderLogical(const UBiDiLevel *levels, int32_t length, int32_t *indexMap)
This is a convenience function that does not use a UBiDi object.
int32_t ubidi_countRuns(UBiDi *pBiDi, UErrorCode *pErrorCode)
Get the number of runs.
void ubidi_setContext(UBiDi *pBiDi, const UChar *prologue, int32_t proLength, const UChar *epilogue, int32_t epiLength, UErrorCode *pErrorCode)
Set the context before a call to ubidi_setPara().
void ubidi_setReorderingOptions(UBiDi *pBiDi, uint32_t reorderingOptions)
Specify which of the reordering options should be applied during Bidi transformations.
int32_t ubidi_writeReordered(UBiDi *pBiDi, UChar *dest, int32_t destSize, uint16_t options, UErrorCode *pErrorCode)
Take a UBiDi object containing the reordering information for a piece of text (one or more paragraphs...
void ubidi_getLogicalMap(UBiDi *pBiDi, int32_t *indexMap, UErrorCode *pErrorCode)
Get a logical-to-visual index map (array) for the characters in the UBiDi (paragraph or line) object.
int32_t ubidi_writeReverse(const UChar *src, int32_t srcLength, UChar *dest, int32_t destSize, uint16_t options, UErrorCode *pErrorCode)
Reverse a Right-To-Left run of Unicode text.
int32_t ubidi_getResultLength(const UBiDi *pBiDi)
Get the length of the reordered text resulting from the last call to ubidi_setPara().
void ubidi_close(UBiDi *pBiDi)
ubidi_close() must be called to free the memory associated with a UBiDi object.
UBiDiReorderingOption
UBiDiReorderingOption values indicate which options are specified to affect the Bidi algorithm.
Definition: ubidi.h:898
@ UBIDI_OPTION_INSERT_MARKS
option bit for ubidi_setReorderingOptions: insert Bidi marks (LRM or RLM) when needed to ensure corre...
Definition: ubidi.h:951
@ UBIDI_OPTION_STREAMING
option bit for ubidi_setReorderingOptions: process the output as part of a stream to be continued
Definition: ubidi.h:1017
@ UBIDI_OPTION_DEFAULT
option value for ubidi_setReorderingOptions: disable all the options which can be set with this funct...
Definition: ubidi.h:905
@ UBIDI_OPTION_REMOVE_CONTROLS
option bit for ubidi_setReorderingOptions: remove Bidi control characters
Definition: ubidi.h:969
void ubidi_setClassCallback(UBiDi *pBiDi, UBiDiClassCallback *newFn, const void *newContext, UBiDiClassCallback **oldFn, const void **oldContext, UErrorCode *pErrorCode)
Set the callback function and callback data used by the UBA implementation for Bidi class determinati...
uint32_t ubidi_getReorderingOptions(UBiDi *pBiDi)
What are the reordering options applied to a given Bidi object?
int32_t ubidi_getParagraph(const UBiDi *pBiDi, int32_t charIndex, int32_t *pParaStart, int32_t *pParaLimit, UBiDiLevel *pParaLevel, UErrorCode *pErrorCode)
Get a paragraph, given a position within the text.
UBool ubidi_isOrderParagraphsLTR(UBiDi *pBiDi)
Is this Bidi object set to allocate level 0 to block separators so that successive paragraphs progres...
void ubidi_getParagraphByIndex(const UBiDi *pBiDi, int32_t paraIndex, int32_t *pParaStart, int32_t *pParaLimit, UBiDiLevel *pParaLevel, UErrorCode *pErrorCode)
Get a paragraph, given the index of this paragraph.
UBiDiLevel ubidi_getParaLevel(const UBiDi *pBiDi)
Get the paragraph level of the text.
UBiDiDirection
UBiDiDirection values indicate the text direction.
Definition: ubidi.h:417
@ UBIDI_LTR
Left-to-right text.
Definition: ubidi.h:429
@ UBIDI_NEUTRAL
No strongly directional text.
Definition: ubidi.h:455
@ UBIDI_MIXED
Mixed-directional text.
Definition: ubidi.h:448
@ UBIDI_RTL
Right-to-left text.
Definition: ubidi.h:441
UCharDirection UBiDiClassCallback(const void *context, UChar32 c)
Callback type declaration for overriding default Bidi class values with custom ones.
Definition: ubidi.h:1991
UBool ubidi_isInverse(UBiDi *pBiDi)
Is this Bidi object set to perform the inverse Bidi algorithm?
UCharDirection ubidi_getCustomizedClass(UBiDi *pBiDi, UChar32 c)
Retrieve the Bidi class for a given code point.
void ubidi_setInverse(UBiDi *pBiDi, UBool isInverse)
Modify the operation of the Bidi algorithm such that it approximates an "inverse Bidi" algorithm.
UBiDiReorderingMode
UBiDiReorderingMode values indicate which variant of the Bidi algorithm to use.
Definition: ubidi.h:687
@ UBIDI_REORDER_INVERSE_FOR_NUMBERS_SPECIAL
Inverse Bidi (Visual to Logical) algorithm for the UBIDI_REORDER_NUMBERS_SPECIAL Bidi algorithm.
Definition: ubidi.h:720
@ UBIDI_REORDER_GROUP_NUMBERS_WITH_R
Logical to Visual algorithm grouping numbers with adjacent R characters (reversible algorithm).
Definition: ubidi.h:699
@ UBIDI_REORDER_RUNS_ONLY
Reorder runs only to transform a Logical LTR string to the Logical RTL string with the same display,...
Definition: ubidi.h:707
@ UBIDI_REORDER_NUMBERS_SPECIAL
Logical to Visual algorithm which handles numbers in a way which mimicks the behavior of Windows XP.
Definition: ubidi.h:695
@ UBIDI_REORDER_INVERSE_NUMBERS_AS_L
Visual to Logical algorithm which handles numbers like L (same algorithm as selected by ubidi_setInve...
Definition: ubidi.h:712
@ UBIDI_REORDER_INVERSE_LIKE_DIRECT
Visual to Logical algorithm equivalent to the regular Logical to Visual algorithm.
Definition: ubidi.h:716
@ UBIDI_REORDER_DEFAULT
Regular Logical to Visual Bidi algorithm according to Unicode.
Definition: ubidi.h:691
@ UBIDI_REORDER_COUNT
Number of values for reordering mode.
Definition: ubidi.h:723
int32_t ubidi_countParagraphs(UBiDi *pBiDi)
Get the number of paragraphs.
int32_t ubidi_getLength(const UBiDi *pBiDi)
Get the length of the text.
int32_t ubidi_getLogicalIndex(UBiDi *pBiDi, int32_t visualIndex, UErrorCode *pErrorCode)
Get the logical text position from a visual position.
UBiDiReorderingMode ubidi_getReorderingMode(UBiDi *pBiDi)
What is the requested reordering mode for a given Bidi object?
UBiDi * ubidi_openSized(int32_t maxLength, int32_t maxRunCount, UErrorCode *pErrorCode)
Allocate a UBiDi structure with preallocated memory for internal structures.
const UBiDiLevel * ubidi_getLevels(UBiDi *pBiDi, UErrorCode *pErrorCode)
Get an array of levels for each character.
void ubidi_getLogicalRun(const UBiDi *pBiDi, int32_t logicalPosition, int32_t *pLogicalLimit, UBiDiLevel *pLevel)
Get a logical run.
uint8_t UBiDiLevel
UBiDiLevel is the type of the level values in this Bidi implementation.
Definition: ubidi.h:330
void ubidi_orderParagraphsLTR(UBiDi *pBiDi, UBool orderParagraphsLTR)
Specify whether block separators must be allocated level zero, so that successive paragraphs will pro...
void ubidi_setPara(UBiDi *pBiDi, const UChar *text, int32_t length, UBiDiLevel paraLevel, UBiDiLevel *embeddingLevels, UErrorCode *pErrorCode)
Perform the Unicode Bidi algorithm.
int32_t ubidi_getProcessedLength(const UBiDi *pBiDi)
Get the length of the source text processed by the last call to ubidi_setPara().
void ubidi_setLine(const UBiDi *pParaBiDi, int32_t start, int32_t limit, UBiDi *pLineBiDi, UErrorCode *pErrorCode)
ubidi_setLine() sets a UBiDi to contain the reordering information, especially the resolved levels,...
UBiDi * ubidi_open(void)
Allocate a UBiDi structure.
UBiDiLevel ubidi_getLevelAt(const UBiDi *pBiDi, int32_t charIndex)
Get the level for one character.
UBiDiDirection ubidi_getVisualRun(UBiDi *pBiDi, int32_t runIndex, int32_t *pLogicalStart, int32_t *pLength)
Get one run's logical start, length, and directionality, which can be 0 for LTR or 1 for RTL.
UBiDiDirection ubidi_getBaseDirection(const UChar *text, int32_t length)
Gets the base direction of the text provided according to the Unicode Bidirectional Algorithm.
struct UBiDi UBiDi
Definition: ubidi.h:474
UBiDiDirection ubidi_getDirection(const UBiDi *pBiDi)
Get the directionality of the text.
void ubidi_getVisualMap(UBiDi *pBiDi, int32_t *indexMap, UErrorCode *pErrorCode)
Get a visual-to-logical index map (array) for the characters in the UBiDi (paragraph or line) object.
void ubidi_invertMap(const int32_t *srcMap, int32_t *destMap, int32_t length)
Invert an index map.
void ubidi_setReorderingMode(UBiDi *pBiDi, UBiDiReorderingMode reorderingMode)
Modify the operation of the Bidi algorithm such that it implements some variant to the basic Bidi alg...
C API: Unicode Properties.
UCharDirection
This specifies the language directional property of a character set.
Definition: uchar.h:807
int32_t UChar32
Define UChar32 as a type for single Unicode code points.
Definition: umachine.h:332
#define U_CDECL_END
This is used to end a declaration of a library private ICU C API.
Definition: umachine.h:83
int8_t UBool
The ICU boolean type.
Definition: umachine.h:234
uint16_t UChar
Define UChar to be UCHAR_TYPE, if that is #defined (for example, to char16_t), or wchar_t if that is ...
Definition: umachine.h:312
#define U_CDECL_BEGIN
This is used to begin a declaration of a library private ICU C API.
Definition: umachine.h:82
#define U_STABLE
This is used to declare a function as a stable public ICU C API.
Definition: umachine.h:109
Basic definitions for ICU, for both C and C++ APIs.
UErrorCode
Error code to replace exception handling, so that the code is compatible with all C++ compilers,...
Definition: utypes.h:476
#define U_NAMESPACE_END
This is used to end a declaration of a public ICU C++ API.
Definition: uversion.h:130
#define U_NAMESPACE_BEGIN
This is used to begin a declaration of a public ICU C++ API.
Definition: uversion.h:129