File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / libiconv / extras / iconv_string.h
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Tue Feb 21 22:57:48 2012 UTC (12 years, 4 months ago) by misho
Branches: libiconv, MAIN
CVS tags: v1_16p0, v1_14p0, v1_14, v1_13_1, HEAD
libiconv

    1: /* Copyright (C) 1999-2001 Bruno Haible.
    2:    This file is not part of the GNU LIBICONV Library.
    3:    This file is put into the public domain.  */
    4: 
    5: /*
    6:  * This C function converts an entire string from one encoding to another,
    7:  * using iconv. Easier to use than iconv() itself, and supports autodetect
    8:  * encodings on input.
    9:  *
   10:  *   int iconv_string (const char* tocode, const char* fromcode,
   11:  *                     const char* start, const char* end,
   12:  *                     char** resultp, size_t* lengthp)
   13:  *
   14:  * Converts a memory region given in encoding FROMCODE to a new memory
   15:  * region in encoding TOCODE. FROMCODE and TOCODE are as for iconv_open(3),
   16:  * except that FROMCODE may be one of the values
   17:  *    "autodetect_utf8"          supports ISO-8859-1 and UTF-8
   18:  *    "autodetect_jp"            supports EUC-JP, ISO-2022-JP-2 and SHIFT_JIS
   19:  *    "autodetect_kr"            supports EUC-KR and ISO-2022-KR
   20:  * The input is in the memory region between start (inclusive) and end
   21:  * (exclusive). If resultp is not NULL, the output string is stored in
   22:  * *resultp; malloc/realloc is used to allocate the result.
   23:  *
   24:  * This function does not treat zero characters specially.
   25:  *
   26:  * Return value: 0 if successful, otherwise -1 and errno set. Particular
   27:  * errno values: EILSEQ and ENOMEM.
   28:  *
   29:  * Example:
   30:  *   const char* s = ...;
   31:  *   char* result = NULL;
   32:  *   if (iconv_string("UCS-4-INTERNAL", "autodetect_utf8",
   33:  *                    s, s+strlen(s)+1, &result, NULL) < 0)
   34:  *     perror("iconv_string");
   35:  *
   36:  */
   37: #include <stddef.h>
   38: 
   39: #ifdef __cplusplus
   40: extern "C" {
   41: #endif
   42: 
   43: extern int iconv_string (const char* tocode, const char* fromcode, const char* start, const char* end, char** resultp, size_t* lengthp);
   44: 
   45: #ifdef __cplusplus
   46: }
   47: #endif

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>