aboutsummaryrefslogtreecommitdiffstats
path: root/irc.c
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2010-04-24 18:02:07 +0100
committerWilmer van der Gaast <wilmer@gaast.net>2010-04-24 18:02:07 +0100
commitae3dc9996f5a678d6364005cab1517b6324eb67a (patch)
treed62ac84957cafa2f956ab82e0ff20505c64f2250 /irc.c
parentb5b40ffd38e315223c6e38e4a291cbd58e471062 (diff)
parentf1b7711f566163ff27a8f13ae3ccc7214a24fe70 (diff)
Merging stuff from mainline (1.2.6).
Diffstat (limited to 'irc.c')
-rw-r--r--irc.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/irc.c b/irc.c
index f631ebd2..4aa8d595 100644
--- a/irc.c
+++ b/irc.c
@@ -52,18 +52,34 @@ static char *set_eval_password( set_t *set, char *value )
static char *set_eval_charset( set_t *set, char *value )
{
irc_t *irc = set->data;
+ char *test;
+ gsize test_bytes = 0;
GIConv ic, oc;
if( g_strcasecmp( value, "none" ) == 0 )
value = g_strdup( "utf-8" );
- if( ( ic = g_iconv_open( "utf-8", value ) ) == (GIConv) -1 )
+ if( ( oc = g_iconv_open( value, "utf-8" ) ) == (GIConv) -1 )
{
return NULL;
}
- if( ( oc = g_iconv_open( value, "utf-8" ) ) == (GIConv) -1 )
+
+ /* Do a test iconv to see if the user picked an IRC-compatible
+ charset (for example utf-16 goes *horribly* wrong). */
+ if( ( test = g_convert_with_iconv( " ", 1, oc, NULL, &test_bytes, NULL ) ) == NULL ||
+ test_bytes > 1 )
+ {
+ g_free( test );
+ g_iconv_close( oc );
+ irc_usermsg( irc, "Unsupported character set: The IRC protocol "
+ "only supports 8-bit character sets." );
+ return NULL;
+ }
+ g_free( test );
+
+ if( ( ic = g_iconv_open( "utf-8", value ) ) == (GIConv) -1 )
{
- g_iconv_close( ic );
+ g_iconv_close( oc );
return NULL;
}
@@ -175,6 +191,7 @@ irc_t *irc_new( int fd )
s = set_add( &irc->set, "debug", "false", set_eval_bool, irc );
s = set_add( &irc->set, "default_target", "root", NULL, irc );
s = set_add( &irc->set, "display_namechanges", "false", set_eval_bool, irc );
+ s = set_add( &irc->set, "display_timestamps", "true", set_eval_bool, irc );
s = set_add( &irc->set, "handle_unknown", "root", NULL, irc );
s = set_add( &irc->set, "lcnicks", "true", set_eval_bool, irc );
s = set_add( &irc->set, "ops", "both", set_eval_ops, irc );
@@ -188,6 +205,7 @@ irc_t *irc_new( int fd )
s = set_add( &irc->set, "status", NULL, set_eval_away_status, irc );
s->flags |= SET_NULL_OK;
s = set_add( &irc->set, "strip_html", "true", NULL, irc );
+ s = set_add( &irc->set, "timezone", "local", set_eval_timezone, irc );
s = set_add( &irc->set, "to_char", ": ", set_eval_to_char, irc );
s = set_add( &irc->set, "typing_notice", "false", set_eval_bool, irc );