diff options
Diffstat (limited to 'src/fe-common')
-rw-r--r-- | src/fe-common/irc/Makefile.am | 1 | ||||
-rw-r--r-- | src/fe-common/irc/fe-channels.c | 10 | ||||
-rw-r--r-- | src/fe-common/irc/fe-common-irc.c | 5 | ||||
-rw-r--r-- | src/fe-common/irc/fe-irc-server.c | 22 | ||||
-rw-r--r-- | src/fe-common/irc/module-formats.c | 6 | ||||
-rw-r--r-- | src/fe-common/irc/module-formats.h | 6 |
6 files changed, 38 insertions, 12 deletions
diff --git a/src/fe-common/irc/Makefile.am b/src/fe-common/irc/Makefile.am index 662caf9d..7c59e0d4 100644 --- a/src/fe-common/irc/Makefile.am +++ b/src/fe-common/irc/Makefile.am @@ -16,6 +16,7 @@ libfe_common_irc_la_SOURCES = \ fe-channels.c \ fe-irc-commands.c \ fe-irc-server.c \ + fe-ircnet.c \ fe-ctcp.c \ fe-events.c \ fe-events-numeric.c \ diff --git a/src/fe-common/irc/fe-channels.c b/src/fe-common/irc/fe-channels.c index 0d566fd7..1859ae7b 100644 --- a/src/fe-common/irc/fe-channels.c +++ b/src/fe-common/irc/fe-channels.c @@ -157,13 +157,13 @@ static void cmd_channel_list(void) g_string_truncate(str, 0); if (rec->autojoin) - g_string_append(str, "autojoin "); + g_string_append(str, "autojoin, "); if (rec->botmasks != NULL && *rec->botmasks != '\0') - g_string_sprintfa(str, "bots: %s ", rec->botmasks); + g_string_sprintfa(str, "bots: %s, ", rec->botmasks); if (rec->autosendcmd != NULL && *rec->autosendcmd != '\0') - g_string_sprintfa(str, "botcmd: %s ", rec->autosendcmd); + g_string_sprintfa(str, "botcmd: %s, ", rec->autosendcmd); - if (str->len > 0) g_string_truncate(str, str->len-1); + if (str->len > 1) g_string_truncate(str, str->len-1); printformat(NULL, NULL, MSGLEVEL_CLIENTCRAP, IRCTXT_CHANSETUP_LINE, rec->name, rec->ircnet == NULL ? "" : rec->ircnet, rec->password == NULL ? "" : rec->password, str->str); @@ -242,8 +242,8 @@ void fe_channels_init(void) signal_add_last("server disconnected", (SIGNAL_FUNC) sig_disconnected); command_bind("wjoin", NULL, (SIGNAL_FUNC) cmd_wjoin); - command_bind("channel ", NULL, (SIGNAL_FUNC) cmd_channel_list_joined); command_bind("channel", NULL, (SIGNAL_FUNC) cmd_channel); + command_bind("channel ", NULL, (SIGNAL_FUNC) cmd_channel_list_joined); command_bind("channel add", NULL, (SIGNAL_FUNC) cmd_channel_add); command_bind("channel remove", NULL, (SIGNAL_FUNC) cmd_channel_remove); command_bind("channel list", NULL, (SIGNAL_FUNC) cmd_channel_list); diff --git a/src/fe-common/irc/fe-common-irc.c b/src/fe-common/irc/fe-common-irc.c index 63430a69..7125dab5 100644 --- a/src/fe-common/irc/fe-common-irc.c +++ b/src/fe-common/irc/fe-common-irc.c @@ -40,6 +40,9 @@ void fe_channels_deinit(void); void fe_irc_commands_init(void); void fe_irc_commands_deinit(void); +void fe_ircnet_init(void); +void fe_ircnet_deinit(void); + void fe_irc_server_init(void); void fe_irc_server_deinit(void); @@ -100,6 +103,7 @@ void fe_common_irc_init(void) fe_channels_init(); fe_irc_commands_init(); + fe_ircnet_init(); fe_irc_server_init(); fe_ctcp_init(); fe_events_init(); @@ -119,6 +123,7 @@ void fe_common_irc_deinit(void) fe_channels_deinit(); fe_irc_commands_deinit(); + fe_ircnet_deinit(); fe_irc_server_deinit(); fe_ctcp_deinit(); fe_events_deinit(); diff --git a/src/fe-common/irc/fe-irc-server.c b/src/fe-common/irc/fe-irc-server.c index ee0978d7..24c662b4 100644 --- a/src/fe-common/irc/fe-irc-server.c +++ b/src/fe-common/irc/fe-irc-server.c @@ -101,14 +101,20 @@ static void server_add(const char *data) if (*portarg != '\0') rec->port = atoi(portarg); if (stristr(args, "-ircnet")) g_free_and_null(rec->ircnet); if (*password != '\0') g_free_and_null(rec->password); - if (stristr(args, "-host")) g_free_and_null(rec->own_host); + if (stristr(args, "-host")) { + g_free_and_null(rec->own_host); + rec->own_ip = NULL; + } } if (stristr(args, "-auto")) rec->autoconnect = TRUE; if (stristr(args, "-noauto")) rec->autoconnect = FALSE; if (*ircnet != '\0') rec->ircnet = g_strdup(ircnet); if (*password != '\0' && strcmp(password, "-") != 0) rec->password = g_strdup(password); - if (*host != '\0') rec->own_host = g_strdup(host); + if (*host != '\0') { + rec->own_host = g_strdup(host); + rec->own_ip = NULL; + } if (*cmdspeed != '\0') rec->cmd_queue_speed = atoi(cmdspeed); if (*cmdmax != '\0') rec->max_cmds_at_once = atoi(cmdmax); @@ -151,15 +157,17 @@ static void server_list(const char *data) g_string_truncate(str, 0); if (rec->password != NULL) - g_string_append(str, "(pass) "); + g_string_append(str, "(pass), "); if (rec->autoconnect) - g_string_append(str, "autoconnect "); + g_string_append(str, "autoconnect, "); if (rec->max_cmds_at_once > 0) - g_string_sprintfa(str, "cmdmax: %d ", rec->max_cmds_at_once); + g_string_sprintfa(str, "cmdmax: %d, ", rec->max_cmds_at_once); if (rec->cmd_queue_speed > 0) - g_string_sprintfa(str, "cmdspeed: %d ", rec->cmd_queue_speed); + g_string_sprintfa(str, "cmdspeed: %d, ", rec->cmd_queue_speed); if (rec->own_host != NULL) - g_string_sprintfa(str, "host: %s ", rec->own_host); + g_string_sprintfa(str, "host: %s, ", rec->own_host); + + if (str->len > 1) g_string_truncate(str, str->len-2); printformat(NULL, NULL, MSGLEVEL_CLIENTCRAP, IRCTXT_SETUPSERVER_LINE, rec->address, rec->port, rec->ircnet == NULL ? "" : rec->ircnet, diff --git a/src/fe-common/irc/module-formats.c b/src/fe-common/irc/module-formats.c index f09f50a4..c20089ff 100644 --- a/src/fe-common/irc/module-formats.c +++ b/src/fe-common/irc/module-formats.c @@ -47,6 +47,12 @@ FORMAT_REC fecommon_irc_formats[] = { { "netsplits_header", "Nick Channel Server Splitted server", 0 }, { "netsplits_line", "$[9]0 $[10]1 $[20]2 $3", 4, { 0, 0, 0, 0 } }, { "netsplits_footer", "", 0 }, + { "ircnet_added", "Ircnet $0 saved", 1, { 0 } }, + { "ircnet_removed", "Ircnet $0 removed", 1, { 0 } }, + { "ircnet_not_found", "Ircnet $0 not found", 1, { 0 } }, + { "ircnet_header", "Ircnets:", 0 }, + { "ircnet_line", "$0: $1", 2, { 0, 0 } }, + { "ircnet_footer", "", 0 }, /* ---- */ { NULL, "Channels", 0 }, diff --git a/src/fe-common/irc/module-formats.h b/src/fe-common/irc/module-formats.h index 56521f47..d4210461 100644 --- a/src/fe-common/irc/module-formats.h +++ b/src/fe-common/irc/module-formats.h @@ -25,6 +25,12 @@ enum { IRCTXT_NETSPLITS_HEADER, IRCTXT_NETSPLITS_LINE, IRCTXT_NETSPLITS_FOOTER, + IRCTXT_IRCNET_ADDED, + IRCTXT_IRCNET_REMOVED, + IRCTXT_IRCNET_NOT_FOUND, + IRCTXT_IRCNET_HEADER, + IRCTXT_IRCNET_LINE, + IRCTXT_IRCNET_FOOTER, IRCTXT_FILL_2, |