Annotation of embedaddon/libiconv/extras/iconv_string.h, revision 1.1

1.1     ! misho       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>