mirror of
https://github.com/irssi/irssi.git
synced 2025-02-02 15:08:01 -05:00
Added an option to specify a charset for a whole network. For example /recode add IRCnet iso-8859-1 (http://bugs.irssi.org/index.php?do=details&id=284) Patch by Sergey Safonov. Replaced g_convert by g_convert_with_fallback in recode_in (http://bugs.irssi.org/index.php?do=details&id=241) Patch by Kuang-che Wu.
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@3881 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
parent
547065cb42
commit
56041a3144
@ -4,14 +4,15 @@
|
||||
RECODE
|
||||
%|List the conversion database
|
||||
|
||||
RECODE ADD %|[[<tag>/]<target>] <charset>
|
||||
%|Add an entry to the conversion database (if target is omitted,
|
||||
the current channel or query will be used). You can specify the
|
||||
<tag> to have different charsets for the same <target> for
|
||||
different networks.
|
||||
RECODE ADD %|<tag>|[<tag>/]<target>] <charset>
|
||||
%|Add an entry to the conversion database (if tag or target is
|
||||
omitted, the current channel or query will be used). You can specify
|
||||
the <tag> to have different charsets for the same <target> for
|
||||
different networks. You can omit the target, and specify only the tag
|
||||
if you want to add an entry for the network.
|
||||
|
||||
RECODE REMOVE %|[<target>]
|
||||
%|Remove an entry from the conversion database (if target is
|
||||
RECODE REMOVE %|[<tag>|<target>]
|
||||
%|Remove an entry from the conversion database (if tag or target is
|
||||
omitted, the current channel or query will be used)
|
||||
|
||||
To specify your local charset you have to set term_charset
|
||||
|
@ -94,16 +94,20 @@ char *recode_in(const SERVER_REC *server, const char *str, const char *target)
|
||||
if (tagtarget != NULL)
|
||||
from = iconfig_get_str("conversions", tagtarget, NULL);
|
||||
g_free(tagtarget);
|
||||
|
||||
if (target != NULL && from == NULL)
|
||||
from = iconfig_get_str("conversions", target, NULL);
|
||||
|
||||
if (from == NULL)
|
||||
from = iconfig_get_str("conversions", server->tag, NULL);
|
||||
|
||||
term_is_utf8 = recode_get_charset(&to);
|
||||
|
||||
if (translit && !is_translit(to))
|
||||
to = translit_to = g_strconcat(to, "//TRANSLIT", NULL);
|
||||
|
||||
if (from)
|
||||
recoded = g_convert(str, len, to, from, NULL, NULL, NULL);
|
||||
recoded = g_convert_with_fallback(str, len, to, from, NULL, NULL, NULL);
|
||||
|
||||
if (!recoded) {
|
||||
if (term_is_utf8) {
|
||||
@ -114,7 +118,7 @@ char *recode_in(const SERVER_REC *server, const char *str, const char *target)
|
||||
from = "UTF-8";
|
||||
|
||||
if (from)
|
||||
recoded = g_convert(str, len, to, from, NULL, NULL, NULL);
|
||||
recoded = g_convert_with_fallback(str, len, to, from, NULL, NULL, NULL);
|
||||
|
||||
if (!recoded)
|
||||
recoded = g_strdup(str);
|
||||
@ -158,6 +162,8 @@ char *recode_out(const SERVER_REC *server, const char *str, const char *target)
|
||||
g_free(tagtarget);
|
||||
if (to == NULL || *to == '\0')
|
||||
to = iconfig_get_str("conversions", target, NULL);
|
||||
if (to == NULL || *to == '\0')
|
||||
to = iconfig_get_str("conversions", server->tag, NULL);
|
||||
if (to == NULL || *to == '\0')
|
||||
/* default outgoing charset if set */
|
||||
to = settings_get_str("recode_out_default_charset");
|
||||
|
Loading…
Reference in New Issue
Block a user