/*
******************************************************************************
*
* © 2016 and later: Unicode, Inc. and others.
* License & terms of use: http://www.unicode.org/copyright.html
*
******************************************************************************
*   file name:  ubiditransform.h
*   encoding:   UTF-8
*   tab size:   8 (not used)
*   indentation:4
*
*   created on: 2016jul24
*   created by: Lina Kemmel
*
*/
#ifndef UBIDITRANSFORM_H
#define UBIDITRANSFORM_H
#include "unicode/utypes.h"
#include "unicode/ubidi.h"
#include "unicode/uchar.h"
#if U_SHOW_CPLUSPLUS_API
#include "unicode/localpointer.h"
#endif   // U_SHOW_CPLUSPLUS_API
/**
 * \file
 * \brief Bidi Transformations
 */
/**
 * `UBiDiOrder` indicates the order of text.
 *
 * This bidi transformation engine supports all possible combinations (4 in
 * total) of input and output text order:
 *
 *   -  
 * In terms of  
 * There are 36 possible combinations of  ordering schemes,
 * which are partially supported by  Example of usage of the transformation engine:UBiDiMirroring indicates whether or not characters with the
 * "mirrored" property in RTL runs should be replaced with their mirror-image
 * counterparts.
 * @see UBIDI_DO_MIRRORING
 * @see ubidi_setReorderingOptions
 * @see ubidi_writeReordered
 * @see ubidi_writeReverse
 * @stable ICU 58
 */
typedef enum {
    /** 0: Constant indicating that character mirroring should not be
      * performed.
      * This is the default.
      * @stable ICU 58
      */
    UBIDI_MIRRORING_OFF = 0,
    /** 1: Constant indicating that character mirroring should be performed.
      * This corresponds to calling ubidi_writeReordered or
      * ubidi_writeReverse with the
      * UBIDI_DO_MIRRORING option bit set.
      * @stable ICU 58
      */
    UBIDI_MIRRORING_ON
} UBiDiMirroring;
/**
 * Forward declaration of the UBiDiTransform structure that stores
 * information used by the layout transformation engine.
 * @stable ICU 58
 */
typedef struct UBiDiTransform UBiDiTransform;
/**
 * Performs transformation of text from the bidi layout defined by the input
 * ordering scheme to the bidi layout defined by the output ordering scheme,
 * and applies character mirroring and Arabic shaping operations.UBiDi, such a transformation implies:
 * 
 * 
 * An "ordering scheme" encompasses the base direction and the order of text,
 * and these characteristics must be defined by the caller for both input and
 * output explicitly .ubidi_setReorderingMode as needed (when the
 * reordering mode is other than normal),ubidi_setInverse as needed (when text should be
 * transformed from a visual to a logical form),ubidi_setPara,ubidi_writeReordered,u_shapeArabic.UBiDi already. Examples of the
 * currently supported combinations:
 * 
 * 
 * All combinations that involve the Visual RTL scheme are unsupported by
 * ubidi_setPara with paraLevel == UBIDI_LTR,ubidi_setPara with paraLevel == UBIDI_RTL,ubidi_setPara with
 * paraLevel == UBIDI_DEFAULT_LTR,ubidi_setPara with
 * paraLevel == UBIDI_DEFAULT_RTL,ubidi_setInverse(UBiDi*, true) and then
 * ubidi_setPara with paraLevel == UBIDI_LTR,ubidi_setInverse(UBiDi*, true) and then
 * ubidi_setPara with paraLevel == UBIDI_RTL.UBiDi, for instance:
 * 
 * 
 * 
 * 
 * \code
 * UChar text1[] = {'a', 'b', 'c', 0x0625, '1', 0};
 * UChar text2[] = {'a', 'b', 'c', 0x0625, '1', 0};
 * UErrorCode errorCode = U_ZERO_ERROR;
 * // Run a transformation.
 * ubiditransform_transform(pBidiTransform,
 *          text1, -1, text2, -1,
 *          UBIDI_LTR, UBIDI_VISUAL,
 *          UBIDI_RTL, UBIDI_LOGICAL,
 *          UBIDI_MIRRORING_OFF,
 *          U_SHAPE_DIGITS_AN2EN | U_SHAPE_DIGIT_TYPE_AN_EXTENDED,
 *          &errorCode);
 * // Do something with text2.
 *  text2[4] = '2';
 * // Run a reverse transformation.
 * ubiditransform_transform(pBidiTransform,
 *          text2, -1, text1, -1,
 *          UBIDI_RTL, UBIDI_LOGICAL,
 *          UBIDI_LTR, UBIDI_VISUAL,
 *          UBIDI_MIRRORING_OFF,
 *          U_SHAPE_DIGITS_EN2AN | U_SHAPE_DIGIT_TYPE_AN_EXTENDED,
 *          &errorCode);
 *\endcode
 * 
 * 
UBiDiTransform object
 *        allocated with ubiditransform_open() or
 *        NULL.
 *        This object serves for one-time setup to amortize initialization
 *        overheads. Use of this object is not thread-safe. All other threads
 *        should allocate a new UBiDiTransform object by calling
 *        ubiditransform_open() before using it. Alternatively,
 *        a caller can set this parameter to NULL, in which case
 *        the object will be allocated by the engine on the fly.
Note: the text must be (at least)
 *        srcLength long.
length == -1 then the text must be zero-terminated.
 * @param dest A pointer to where the processed text is to be copied.
 * @param destSize The size of the dest buffer, in number of
 *        UChars. If the U_SHAPE_LETTERS_UNSHAPE option is set,
 *        then the destination length could be as large as
 *        srcLength * 2. Otherwise, the destination length will
 *        not exceed srcLength. If the caller reserves the last
 *        position for zero-termination, it should be excluded from
 *        destSize.
 *        destSize == -1 is allowed and makes sense when
 *        dest was holds some meaningful value, e.g. that of
 *        src. In this case dest must be
 *        zero-terminated.
ubidi_setPara documentation for the
 *        paraLevel parameter.
 * @param inOrder An order of the input, which can be one of the
 *        UBiDiOrder values.
 * @param outParaLevel A base embedding level of the output as defined in
 *        ubidi_setPara documentation for the
 *        paraLevel parameter.
 * @param outOrder An order of the output, which can be one of the
 *        UBiDiOrder values.
 * @param doMirroring Indicates whether or not to perform character mirroring,
 *        and can accept one of the UBiDiMirroring values.
 * @param shapingOptions Arabic digit and letter shaping options defined in the
 *        ushape.h documentation.
 *        Note: Direction indicator options are computed by * the transformation engine based on the effective ordering schemes, so * user-defined direction indicators will be ignored.
* @param pErrorCode A pointer to an error code value. * * @return The destination length, i.e. the number of UChars written to *dest. If the transformation fails, the return value
 *         will be 0 (and the error code will be written to
 *         pErrorCode).
 *
 * @see UBiDiLevel
 * @see UBiDiOrder
 * @see UBiDiMirroring
 * @see ubidi_setPara
 * @see u_shapeArabic
 * @stable ICU 58
 */
U_CAPI uint32_t U_EXPORT2
ubiditransform_transform(UBiDiTransform *pBiDiTransform,
            const UChar *src, int32_t srcLength,
            UChar *dest, int32_t destSize,
            UBiDiLevel inParaLevel, UBiDiOrder inOrder,
            UBiDiLevel outParaLevel, UBiDiOrder outOrder,
            UBiDiMirroring doMirroring, uint32_t shapingOptions,
            UErrorCode *pErrorCode);
/**
 * Allocates a UBiDiTransform object. This object can be reused,
 * e.g. with different ordering schemes, mirroring or shaping options.
 * Note:The object can only be reused in the same thread.
 * All other threads should allocate a new UBiDiTransform object
 * before using it.
* Example of usage:
*
* \code * UErrorCode errorCode = U_ZERO_ERROR; * // Open a new UBiDiTransform. * UBiDiTransform* transform = ubiditransform_open(&errorCode); * // Run a transformation. * ubiditransform_transform(transform, * text1, -1, text2, -1, * UBIDI_RTL, UBIDI_LOGICAL, * UBIDI_LTR, UBIDI_VISUAL, * UBIDI_MIRRORING_ON, * U_SHAPE_DIGITS_EN2AN, * &errorCode); * // Do something with the output text and invoke another transformation using * // that text as input. * ubiditransform_transform(transform, * text2, -1, text3, -1, * UBIDI_LTR, UBIDI_VISUAL, * UBIDI_RTL, UBIDI_VISUAL, * UBIDI_MIRRORING_ON, * 0, &errorCode); *\endcode **
 * The UBiDiTransform object must be deallocated by calling
 * ubiditransform_close().
 *
 * @return An empty UBiDiTransform object.
 * @stable ICU 58
 */
U_CAPI UBiDiTransform* U_EXPORT2
ubiditransform_open(UErrorCode *pErrorCode);
/**
 * Deallocates the given UBiDiTransform object.
 * @stable ICU 58
 */
U_CAPI void U_EXPORT2
ubiditransform_close(UBiDiTransform *pBidiTransform);
#if U_SHOW_CPLUSPLUS_API
U_NAMESPACE_BEGIN
/**
 * \class LocalUBiDiTransformPointer
 * "Smart pointer" class, closes a UBiDiTransform via ubiditransform_close().
 * For most methods see the LocalPointerBase base class.
 *
 * @see LocalPointerBase
 * @see LocalPointer
 * @stable ICU 58
 */
U_DEFINE_LOCAL_OPEN_POINTER(LocalUBiDiTransformPointer, UBiDiTransform, ubiditransform_close);
U_NAMESPACE_END
#endif
#endif