2003-11-26 15:16:36 +08:00
|
|
|
/* $OpenLDAP$ */
|
|
|
|
/* This work is part of OpenLDAP Software <http://www.openldap.org/>.
|
|
|
|
*
|
2005-01-02 04:49:32 +08:00
|
|
|
* Copyright 1998-2005 The OpenLDAP Foundation.
|
2003-11-26 15:16:36 +08:00
|
|
|
* All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted only as authorized by the OpenLDAP
|
|
|
|
* Public License.
|
|
|
|
*
|
|
|
|
* A copy of this license is available in file LICENSE in the
|
|
|
|
* top-level directory of the distribution or, alternatively, at
|
|
|
|
* <http://www.OpenLDAP.org/license.html>.
|
|
|
|
*/
|
|
|
|
/* Copyright 1999 Computing Research Labs, New Mexico State University
|
2000-01-26 06:38:34 +08:00
|
|
|
*
|
|
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
|
|
* to deal in the Software without restriction, including without limitation
|
|
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
|
|
*
|
|
|
|
* The above copyright notice and this permission notice shall be included in
|
|
|
|
* all copies or substantial portions of the Software.
|
|
|
|
*
|
|
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
|
|
* THE COMPUTING RESEARCH LAB OR NEW MEXICO STATE UNIVERSITY BE LIABLE FOR ANY
|
|
|
|
* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT
|
|
|
|
* OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR
|
|
|
|
* THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
|
|
*/
|
2003-11-26 15:16:36 +08:00
|
|
|
/* $Id: ucpgba.h,v 1.4 1999/11/19 15:24:30 mleisher Exp $ */
|
|
|
|
|
2000-01-26 06:38:34 +08:00
|
|
|
#ifndef _h_ucpgba
|
|
|
|
#define _h_ucpgba
|
|
|
|
|
2000-01-27 09:00:02 +08:00
|
|
|
#include "portable.h"
|
|
|
|
|
|
|
|
LDAP_BEGIN_DECL
|
2000-01-26 06:38:34 +08:00
|
|
|
|
|
|
|
/***************************************************************************
|
|
|
|
*
|
|
|
|
* Macros and types.
|
|
|
|
*
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* These are the direction values that can appear in render runs and render
|
|
|
|
* strings.
|
|
|
|
*/
|
|
|
|
#define UCPGBA_LTR 0
|
|
|
|
#define UCPGBA_RTL 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
* These are the flags for cursor motion.
|
|
|
|
*/
|
|
|
|
#define UCPGBA_CURSOR_VISUAL 0
|
|
|
|
#define UCPGBA_CURSOR_LOGICAL 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This structure is used to contain runs of text in a particular direction.
|
|
|
|
*/
|
|
|
|
typedef struct _ucrun_t {
|
|
|
|
struct _ucrun_t *visual_prev; /* Pointer to the previous visual run. */
|
|
|
|
struct _ucrun_t *visual_next; /* Pointer to the next visual run. */
|
|
|
|
|
|
|
|
struct _ucrun_t *logical_prev; /* Pointer to the previous logical run. */
|
|
|
|
struct _ucrun_t *logical_next; /* Pointer to the next logical run. */
|
|
|
|
|
|
|
|
int direction; /* Direction of the run. */
|
|
|
|
|
|
|
|
long cursor; /* Position of "cursor" in the string. */
|
|
|
|
|
|
|
|
unsigned long *chars; /* List of characters for the run. */
|
|
|
|
unsigned long *positions; /* List of original positions in source. */
|
|
|
|
|
|
|
|
unsigned long *source; /* The source string. */
|
|
|
|
unsigned long start; /* Beginning offset in the source string. */
|
|
|
|
unsigned long end; /* Ending offset in the source string. */
|
|
|
|
} ucrun_t;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This represents a string of runs rendered up to a point that is not
|
|
|
|
* platform specific.
|
|
|
|
*/
|
|
|
|
typedef struct _ucstring_t {
|
|
|
|
int direction; /* Overall direction of the string. */
|
|
|
|
|
|
|
|
int cursor_motion; /* Logical or visual cursor motion flag. */
|
|
|
|
|
|
|
|
ucrun_t *cursor; /* The run containing the "cursor." */
|
|
|
|
|
|
|
|
ucrun_t *logical_first; /* First run in the logical order. */
|
|
|
|
ucrun_t *logical_last; /* Last run in the logical order. */
|
|
|
|
|
|
|
|
ucrun_t *visual_first; /* First run in the visual order. */
|
|
|
|
ucrun_t *visual_last; /* Last run in the visual order. */
|
|
|
|
|
|
|
|
unsigned long *source; /* The source string. */
|
|
|
|
unsigned long start; /* The beginning offset in the source. */
|
|
|
|
unsigned long end; /* The ending offset in the source. */
|
|
|
|
} ucstring_t;
|
|
|
|
|
|
|
|
/***************************************************************************
|
|
|
|
*
|
|
|
|
* API
|
|
|
|
*
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This creates and reorders the specified substring using the
|
|
|
|
* "Pretty Good Bidi Algorithm." A default direction is provided for cases
|
|
|
|
* of a string containing no strong direction characters and the default
|
|
|
|
* cursor motion should be provided.
|
|
|
|
*/
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUNICODE_F (ucstring_t *)
|
|
|
|
ucstring_create LDAP_P((unsigned long *source,
|
|
|
|
unsigned long start,
|
|
|
|
unsigned long end,
|
|
|
|
int default_direction,
|
|
|
|
int cursor_motion));
|
2000-01-26 06:38:34 +08:00
|
|
|
/*
|
|
|
|
* This releases the string.
|
|
|
|
*/
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUNICODE_F (void) ucstring_free LDAP_P((ucstring_t *string));
|
2000-01-26 06:38:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This changes the cursor motion flag for the string.
|
|
|
|
*/
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUNICODE_F (int)
|
|
|
|
ucstring_set_cursor_motion LDAP_P((ucstring_t *string,
|
|
|
|
int cursor_motion));
|
2000-01-26 06:38:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This function will move the cursor to the right depending on the
|
|
|
|
* type of cursor motion that was specified for the string.
|
|
|
|
*
|
|
|
|
* A 0 is returned if no cursor motion is performed, otherwise a
|
|
|
|
* 1 is returned.
|
|
|
|
*/
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUNICODE_F (int)
|
|
|
|
ucstring_cursor_right LDAP_P((ucstring_t *string, int count));
|
2000-01-26 06:38:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This function will move the cursor to the left depending on the
|
|
|
|
* type of cursor motion that was specified for the string.
|
|
|
|
*
|
|
|
|
* A 0 is returned if no cursor motion is performed, otherwise a
|
|
|
|
* 1 is returned.
|
|
|
|
*/
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUNICODE_F (int)
|
|
|
|
ucstring_cursor_left LDAP_P((ucstring_t *string, int count));
|
2000-01-26 06:38:34 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* This routine retrieves the direction of the run containing the cursor
|
|
|
|
* and the actual position in the original text string.
|
|
|
|
*/
|
2001-12-07 12:03:25 +08:00
|
|
|
LDAP_LUNICODE_F (void)
|
|
|
|
ucstring_cursor_info LDAP_P((ucstring_t *string, int *direction,
|
|
|
|
unsigned long *position));
|
2000-01-26 06:38:34 +08:00
|
|
|
|
2000-01-27 09:00:02 +08:00
|
|
|
LDAP_END_DECL
|
2000-01-26 06:38:34 +08:00
|
|
|
|
|
|
|
#endif /* _h_ucpgba */
|