annotate libpurple/protocols/oscar/encoding.h @ 30384:42862490dcb7

Damn it.
author ivan.komarov@soc.pidgin.im
date Mon, 26 Jul 2010 17:02:32 +0000
parents
children 9d386bf63eab
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
30384
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
1 /*
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
2 * Purple's oscar protocol plugin
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
3 * This file is the legal property of its developers.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
4 * Please see the AUTHORS file distributed alongside this file.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
5 *
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
6 * This library is free software; you can redistribute it and/or
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
7 * modify it under the terms of the GNU Lesser General Public
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
8 * License as published by the Free Software Foundation; either
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
9 * version 2 of the License, or (at your option) any later version.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
10 *
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
11 * This library is distributed in the hope that it will be useful,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
14 * Lesser General Public License for more details.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
15 *
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
16 * You should have received a copy of the GNU Lesser General Public
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
17 * License along with this library; if not, write to the Free Software
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111-1301 USA
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
19 */
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
20
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
21 #ifndef _ENCODING_H_
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
22 #define _ENCODING_H_
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
23
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
24 #include "oscar.h"
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
25 #include "oscarcommon.h"
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
26
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
27 /**
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
28 * Determine the simplest encoding we can send this message in.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
29 */
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
30 guint32 oscar_charset_check(const char *utf8);
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
31
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
32 /**
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
33 * Take a string of the form charset="bleh" where bleh is
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
34 * one of us-ascii, utf-8, iso-8859-1, or unicode-2-0, and
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
35 * return a newly allocated string containing bleh.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
36 */
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
37 gchar * oscar_encoding_extract(const char *encoding);
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
38
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
39 gchar * oscar_encoding_to_utf8(PurpleAccount *account, const char *encoding, const char *text, int textlen);
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
40 gchar * oscar_utf8_try_convert(PurpleAccount *account, OscarData *od, const gchar *msg);
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
41
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
42 /**
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
43 * This attemps to decode an incoming IM into a UTF8 string.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
44 *
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
45 * We try decoding using two different character sets. The charset
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
46 * specified in the IM determines the order in which we attempt to
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
47 * decode. We do this because there are lots of broken ICQ clients
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
48 * that don't correctly send non-ASCII messages. And if Purple isn't
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
49 * able to deal with that crap, then people complain like banshees.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
50 */
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
51 gchar * oscar_decode_im_part(PurpleAccount *account,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
52 const char *sourcebn,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
53 guint16 charset, guint16 charsubset,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
54 const gchar *data, gsize datalen);
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
55
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
56 /**
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
57 * Figure out what encoding to use when sending a given outgoing message.
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
58 */
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
59 void oscar_convert_to_best_encoding(PurpleConnection *gc,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
60 const char *destbn, const gchar *from,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
61 gchar **msg, int *msglen_int,
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
62 guint16 *charset, guint16 *charsubset);
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
63
42862490dcb7 Damn it.
ivan.komarov@soc.pidgin.im
parents:
diff changeset
64 #endif