annotate src/protocols/gg/iconv_string.h @ 2791:8f6365332a05

[gaim-migrate @ 2804] i hate this shit. i should just stop hacking gaim. committer: Tailor Script <tailor@pidgin.im>
author Eric Warmenhoven <eric@warmenhoven.org>
date Mon, 26 Nov 2001 20:39:54 +0000
parents 8229710b343b
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2541
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
1 /* Copyright (C) 1999-2001 Bruno Haible.
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
2 This file is not part of the GNU LIBICONV Library.
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
3 This file is put into the public domain. */
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
4
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
5 /*
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
6 * This C function converts an entire string from one encoding to another,
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
7 * using iconv. Easier to use than iconv() itself, and supports autodetect
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
8 * encodings on input.
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
9 *
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
10 * int iconv_string (const char* tocode, const char* fromcode,
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
11 * const char* start, const char* end,
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
12 * char** resultp, size_t* lengthp)
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
13 *
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
14 * Converts a memory region given in encoding FROMCODE to a new memory
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
15 * region in encoding TOCODE. FROMCODE and TOCODE are as for iconv_open(3),
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
16 * except that FROMCODE may be one of the values
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
17 * "autodetect_utf8" supports ISO-8859-1 and UTF-8
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
18 * "autodetect_jp" supports EUC-JP, ISO-2022-JP-2 and SHIFT_JIS
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
19 * "autodetect_kr" supports EUC-KR and ISO-2022-KR
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
20 * The input is in the memory region between start (inclusive) and end
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
21 * (exclusive). If resultp is not NULL, the output string is stored in
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
22 * *resultp; malloc/realloc is used to allocate the result.
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
23 *
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
24 * This function does not treat zero characters specially.
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
25 *
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
26 * Return value: 0 if successful, otherwise -1 and errno set. Particular
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
27 * errno values: EILSEQ and ENOMEM.
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
28 *
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
29 * Example:
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
30 * const char* s = ...;
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
31 * char* result = NULL;
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
32 * if (iconv_string("UCS-4-INTERNAL", "autodetect_utf8",
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
33 * s, s+strlen(s)+1, &result, NULL) < 0)
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
34 * perror("iconv_string");
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
35 *
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
36 */
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
37 #include <stddef.h>
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
38
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
39 #ifdef __cplusplus
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
40 extern "C" {
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
41 #endif
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
42
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
43 extern int iconv_string (const char* tocode, const char* fromcode, const char* start, const char* end, char** resultp, size_t* lengthp);
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
44
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
45 #ifdef __cplusplus
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
46 }
8229710b343b [gaim-migrate @ 2554]
Eric Warmenhoven <eric@warmenhoven.org>
parents:
diff changeset
47 #endif