⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 conv.h

📁 Newlib 嵌入式 C库 标准实现代码
💻 H
字号:
/* * Copyright (c) 2003-2004, Artem B. Bityuckiy * Copyright (c) 1999,2000, Konstantin Chuguev. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in the *    documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. */#ifndef __ICONV_CONVERSION_H__#define __ICONV_CONVERSION_H__#include <_ansi.h>#include <reent.h>#include <sys/types.h>#include <wchar.h>/* Bits for 'flags' parameter of 'convert' call */#define ICONV_DONT_SAVE_BIT 1#define ICONV_FAIL_BIT      2/* * iconv_conversion_handlers_t - keeps iconv conversion handlers. * * Keeps 6 interface function handlers: * open(), close(), convert(), get_mb_cur_max(), get_state(), set_state(), * get_mb_cur_max() and is_stateful(). Last 5 interface functions are needed to * support locale subsystem. * * ============================================================================ */typedef struct{  /*   * open - open and initialize conversion.   *   * PARAMETERS:   *   struct _reent *rptr - reent structure of current thread/process;   *   _CONST char *to     - output encoding's normalized name;   *   _CONST char *from   - input encoding's normalized name.   *    * DESCRIPTION:   *   This function is called from iconv_open() to open conversion. Returns   *   a pointer to conversion-specific data.   *   * RETURN:   *   Pointer to conversion-specific data if success. In case of error   *   returns NULL and sets current thread's/process's errno.   */  _VOID_PTR _EXPARM(open, (struct _reent *rptr,                          _CONST char *to,                          _CONST char *from));    /*   * close - close conversion.   *   * PARAMETRS:   *   struct _reent *rptr - reent structure of current thread/process;   *   _VOID_PTR data      - conversion-specific data.   *   * DESCRIPTION:   *   This function is called from iconv_close() to close conversion.   *   * RETURN:   *   When successful, returns (size_t)0. In case of error, sets current   *   thread's/process's errno and returns (size_t)-1 (same as iconv_open()).   */  size_t _EXPARM(close, (struct _reent *rptr,                        _VOID_PTR data));    /* convert - perform encoding conversion.   *   * PARAMETERS:   *   struct _reent *rptr - reent structure of current thread/process.   *   _VOID_PTR data      - conversion-specific data;   *   _CONST unsigned char **inbuf - input data buffer;   *   size_t *inbytesleft          - input buffer's length;   *   unsigned char **outbuf       - output data buffer;   *   size_t *outbytesleft         - output buffer free space;   *   int flags                    - conversion options.   *   * DESCRIPTION:   *   This function is called from iconv() to perform conversion and, if 'flags'   *   is 0, behaves similarly to iconv(). 'inbuf', 'inbytesleft', 'outbuf' and   *   'outbytesleft' are same as in case of iconv() function.   *   *   When flags & 1 isn't 0, 'outbuf' value is ignored and result isn't saved.   *   Another conversion aspects aren't changed.   *   *   When flags & 2 isn't 0, function changes it's behavior in situations,   *   when there is no character in "to" encoding that corresponds to valid   *   character from "from" encoding. iconv() specification stands to perform   *   implimentation-spacific default conversion. If flag & 2 isn't 0,   *   function generates error.   *   * RETURN:   *   Returns the number of characters converted in a non-reversible way.   *   Reversible conversions are not counted. In case of error, sets current   *   thread's/process's errno and returns (size_t)-1 (same as iconv()).   */  size_t _EXPARM(convert, (struct _reent *rptr,                           _VOID_PTR data,                           _CONST unsigned char **inbuf,                           size_t *inbytesleft,                           unsigned char **outbuf,                           size_t *outbytesleft,                           int flags));    /*   * get_state - get current shift state.   *   * PARAMETERS:   *   _VOID_PTR data   - conversion-specific data;   *   mbstate_t *state - mbstate_t object where shift state will be written;   *   int direction      - 0-"from", 1-"to".   *   * DESCRIPTION:   *   Returns encoding's current shift sequence.   *   If 'direction' is 0, "from" encoding is tested, else   *   "to" encoding is tested.   */  _VOID _EXPARM(get_state, (_VOID_PTR data,                           mbstate_t *state,                           int direction));  /*   * set_state - set shift state.   *   * PARAMETERS:   *   _VOID_PTR data   - conversion-specific data;   *   mbstate_t *state - mbstate_t object to which shift state will be set.   *   int direction     - 0-"from", 1-"to".   *   * DESCRIPTION:   *   Sets encoding's current shift state to 'state'. if 'state'   *   object is zero-object - reset current shift state.   *   If 'direction' is 0, "from" encoding is set, else   *   "to" encoding is set.   *   Returns 0 if '*state' object has right format, -1 else.   */  int _EXPARM(set_state, (_VOID_PTR data,                         mbstate_t *state,                         int direction));    /*   * get_mb_cur_max - get maximum character length in bytes.   *   * PARAMETERS:   *   _VOID_PTR data     - conversion-specific data;   *   int direction      - 0-"from", 1-"to".   *   * DESCRIPTION:   *   Returns encoding's maximum character length.   *   If 'direction' is 0, "from" encoding is tested, else   *   "to" encoding is tested.   */  int _EXPARM(get_mb_cur_max, (_VOID_PTR data,                              int direction));    /*   * is_stateful - is encoding stateful or stateless.   *   * PARAMETERS:   *   _VOID_PTR data - conversion-specific data;   *   int direction  - 0-"from", 1-"to".   *   * DESCRIPTION:   *   Returns 0 if encoding is stateless and 1 if stateful.   *   If 'direction' is 0, "from" encoding is tested, else   *   "to" encoding is tested.   */  int _EXPARM(is_stateful, (_VOID_PTR data,                           int direction));  } iconv_conversion_handlers_t;/* * iconv_conversion_t - iconv conversion definition structure. * * ============================================================================ */typedef struct{  /* Iconv conversion handlers. */  _CONST iconv_conversion_handlers_t *handlers;    /*   * Conversion-specific data (e.g., points to iconv_ucs_conversion_t   * object if UCS-based conversion is used).   */  _VOID_PTR data;} iconv_conversion_t;/* UCS-based conversion handlers */extern _CONST iconv_conversion_handlers_t_iconv_ucs_conversion_handlers;/* Null conversion handlers */extern _CONST iconv_conversion_handlers_t_iconv_null_conversion_handlers;#endif /* !__ICONV_CONVERSION_H__ */

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -