diff options
Diffstat (limited to 'src/irc')
-rw-r--r-- | src/irc/core/irc-channels.c | 33 | ||||
-rw-r--r-- | src/irc/core/irc-chatnets.c | 87 | ||||
-rw-r--r-- | src/irc/core/irc-commands.c | 2 | ||||
-rw-r--r-- | src/irc/core/irc-core.c | 38 | ||||
-rw-r--r-- | src/irc/core/irc-queries.c | 17 | ||||
-rw-r--r-- | src/irc/core/irc-servers-setup.c | 37 | ||||
-rw-r--r-- | src/irc/core/irc-servers.c | 13 |
7 files changed, 71 insertions, 156 deletions
diff --git a/src/irc/core/irc-channels.c b/src/irc/core/irc-channels.c index bdef9468..a083c9d0 100644 --- a/src/irc/core/irc-channels.c +++ b/src/irc/core/irc-channels.c @@ -62,22 +62,6 @@ IRC_CHANNEL_REC *irc_channel_create(IRC_SERVER_REC *server, return rec; } -static void sig_channel_create(IRC_CHANNEL_REC **channel, - void *chat_type, IRC_SERVER_REC *server, - const char *name, void *automatic) -{ - if (chat_protocol_lookup("IRC") != GPOINTER_TO_INT(chat_type)) - return; - - g_return_if_fail(server == NULL || IS_IRC_SERVER(server)); - g_return_if_fail(channel != NULL); - g_return_if_fail(name != NULL); - - *channel = irc_channel_create(server, name, - GPOINTER_TO_INT(automatic)); - signal_stop(); -} - static void sig_channel_destroyed(IRC_CHANNEL_REC *channel) { if (!IS_IRC_CHANNEL(channel)) @@ -93,11 +77,11 @@ static void sig_channel_destroyed(IRC_CHANNEL_REC *channel) #define get_join_key(key) \ (((key) == NULL || *(key) == '\0') ? "x" : (key)) -static void irc_channels_join(SERVER_REC *server, const char *data, +static void irc_channels_join(IRC_SERVER_REC *server, const char *data, int automatic) { CHANNEL_SETUP_REC *schannel; - CHANNEL_REC *chanrec; + IRC_CHANNEL_REC *chanrec; GString *outchans, *outkeys; char *channels, *keys, *key; char **chanlist, **keylist, **tmp, **tmpkey, *channel, *channame; @@ -124,9 +108,9 @@ static void irc_channels_join(SERVER_REC *server, const char *data, channel = ischannel(**tmp) ? g_strdup(*tmp) : g_strdup_printf("#%s", *tmp); - chanrec = channel_find(server, channel); + chanrec = irc_channel_find(server, channel); if (chanrec == NULL) { - schannel = channels_setup_find(channel, server->connrec->chatnet); + schannel = channel_setup_find(channel, server->connrec->chatnet); g_string_sprintfa(outchans, "%s,", channel); if (*tmpkey != NULL && **tmpkey != '\0') @@ -140,8 +124,8 @@ static void irc_channels_join(SERVER_REC *server, const char *data, g_string_sprintfa(outkeys, "%s,", get_join_key(key)); channame = channel + (channel[0] == '!' && channel[1] == '!'); - chanrec = channel_create(server->chat_type, server, - channame, automatic); + chanrec = irc_channel_create(server, channame, + automatic); if (key != NULL) chanrec->key = g_strdup(key); } g_free(channel); @@ -197,12 +181,12 @@ static void sig_server_looking(SERVER_REC *server) return; server->channel_find_func = irc_channel_find_server; - server->channels_join = irc_channels_join; + server->channels_join = (void (*) (SERVER_REC *, const char *, int)) + irc_channels_join; } void irc_channels_init(void) { - signal_add("channel create", (SIGNAL_FUNC) sig_channel_create); signal_add("server looking", (SIGNAL_FUNC) sig_server_looking); signal_add("channel destroyed", (SIGNAL_FUNC) sig_channel_destroyed); @@ -220,7 +204,6 @@ void irc_channels_init(void) void irc_channels_deinit(void) { - signal_remove("channel create", (SIGNAL_FUNC) sig_channel_create); signal_remove("server looking", (SIGNAL_FUNC) sig_server_looking); signal_remove("channel destroyed", (SIGNAL_FUNC) sig_channel_destroyed); diff --git a/src/irc/core/irc-chatnets.c b/src/irc/core/irc-chatnets.c index 40c4cae1..4ebf71f6 100644 --- a/src/irc/core/irc-chatnets.c +++ b/src/irc/core/irc-chatnets.c @@ -20,23 +20,23 @@ #include "module.h" #include "signals.h" -#include "servers.h" -#include "chatnets.h" -#include "special-vars.h" #include "lib-config/iconfig.h" #include "settings.h" #include "irc-chatnets.h" -static void ircnet_read(CONFIG_NODE *node) +void ircnet_create(IRC_CHATNET_REC *rec) { - IRC_CHATNET_REC *rec; - - if (node == NULL || node->key == NULL) - return; + g_return_if_fail(rec != NULL); - rec = g_new0(IRC_CHATNET_REC, 1); rec->chat_type = IRC_PROTOCOL; + chatnet_create(CHATNET(rec)); +} + +static void sig_chatnet_read(IRC_CHATNET_REC *rec, CONFIG_NODE *node) +{ + if (!IS_IRC_CHATNET(rec)) + return; rec->max_cmds_at_once = config_node_get_int(node, "cmdmax", 0); rec->cmd_queue_speed = config_node_get_int(node, "cmdspeed", 0); @@ -46,18 +46,12 @@ static void ircnet_read(CONFIG_NODE *node) rec->max_msgs = config_node_get_int(node, "max_msgs", 0); rec->max_modes = config_node_get_int(node, "max_modes", 0); rec->max_whois = config_node_get_int(node, "max_whois", 0); - - chatnet_read((CHATNET_REC *) rec, node); } -static void ircnet_save(IRC_CHATNET_REC *rec) +static void sig_chatnet_saved(IRC_CHATNET_REC *rec, CONFIG_NODE *node) { - CONFIG_NODE *node; - - g_return_if_fail(rec != NULL); - - node = iconfig_node_traverse("ircnets", TRUE); - node = chatnet_save((CHATNET_REC *) rec, node); + if (!IS_IRC_CHATNET(rec)) + return; if (rec->max_cmds_at_once > 0) iconfig_node_set_int(node, "cmdmax", rec->max_cmds_at_once); @@ -76,63 +70,14 @@ static void ircnet_save(IRC_CHATNET_REC *rec) iconfig_node_set_int(node, "max_whois", rec->max_whois); } -static void ircnet_remove(IRC_CHATNET_REC *rec) -{ - CONFIG_NODE *node; - - g_return_if_fail(IS_IRC_CHATNET(rec)); - - node = iconfig_node_traverse("ircnets", FALSE); - if (node != NULL) iconfig_node_set_str(node, rec->name, NULL); -} - -void ircnet_create(IRC_CHATNET_REC *rec) -{ - g_return_if_fail(rec != NULL); - - rec->chat_type = IRC_PROTOCOL; - - ircnet_save(rec); - chatnet_create((CHATNET_REC *) rec); -} - -static void read_ircnets(void) -{ - CONFIG_NODE *node; - GSList *tmp, *next; - - for (tmp = chatnets; tmp != NULL; tmp = next) { - CHATNET_REC *rec = tmp->data; - - next = tmp->next; - if (IS_IRCNET(rec)) - chatnet_destroy(rec); - } - - /* read ircnets */ - node = iconfig_node_traverse("ircnets", FALSE); - if (node != NULL) { - for (tmp = node->value; tmp != NULL; tmp = tmp->next) - ircnet_read(tmp->data); - } -} - -static void sig_chatnet_removed(IRC_CHATNET_REC *rec) -{ - if (IS_IRC_CHATNET(rec)) - ircnet_remove(rec); -} - void irc_chatnets_init(void) { - read_ircnets(); - - signal_add("chatnet removed", (SIGNAL_FUNC) sig_chatnet_removed); - signal_add("setup reread", (SIGNAL_FUNC) read_ircnets); + signal_add("chatnet read", (SIGNAL_FUNC) sig_chatnet_read); + signal_add("chatnet saved", (SIGNAL_FUNC) sig_chatnet_saved); } void irc_chatnets_deinit(void) { - signal_remove("chatnet removed", (SIGNAL_FUNC) sig_chatnet_removed); - signal_remove("setup reread", (SIGNAL_FUNC) read_ircnets); + signal_remove("chatnet read", (SIGNAL_FUNC) sig_chatnet_read); + signal_remove("chatnet saved", (SIGNAL_FUNC) sig_chatnet_saved); } diff --git a/src/irc/core/irc-commands.c b/src/irc/core/irc-commands.c index 3c32b3ec..44abb416 100644 --- a/src/irc/core/irc-commands.c +++ b/src/irc/core/irc-commands.c @@ -78,7 +78,7 @@ static SERVER_REC *irc_connect_server(const char *data) *password = '\0'; /* connect to server */ - conn = server_create_conn(addr, atoi(portstr), password, nick); + conn = server_create_conn(-1, addr, atoi(portstr), password, nick); if (g_hash_table_lookup(optlist, "6") != NULL) conn->family = AF_INET6; else if (g_hash_table_lookup(optlist, "4") != NULL) diff --git a/src/irc/core/irc-core.c b/src/irc/core/irc-core.c index 0dc19443..6671c33a 100644 --- a/src/irc/core/irc-core.c +++ b/src/irc/core/irc-core.c @@ -26,6 +26,9 @@ #include "irc-channels.h" #include "irc-queries.h" +#include "irc-servers-setup.h" +#include "channels-setup.h" + #include "ctcp.h" #include "irc.h" #include "netsplit.h" @@ -45,6 +48,26 @@ void irc_log_deinit(void); void lag_init(void); void lag_deinit(void); +static CHATNET_REC *create_chatnet(void) +{ + return g_malloc0(sizeof(IRC_CHATNET_REC)); +} + +static SERVER_SETUP_REC *create_server_setup(void) +{ + return g_malloc0(sizeof(IRC_SERVER_SETUP_REC)); +} + +static CHANNEL_SETUP_REC *create_channel_setup(void) +{ + return g_malloc0(sizeof(CHANNEL_SETUP_REC)); +} + +static SERVER_CONNECT_REC *create_server_connect(void) +{ + return g_malloc0(sizeof(IRC_SERVER_CONNECT_REC)); +} + void irc_core_init(void) { CHAT_PROTOCOL_REC *rec; @@ -54,7 +77,22 @@ void irc_core_init(void) rec->fullname = "Internet Relay Chat"; rec->chatnet = "ircnet"; + rec->create_chatnet = create_chatnet; + rec->create_server_setup = create_server_setup; + rec->create_channel_setup = create_channel_setup; + rec->create_server_connect = create_server_connect; + + rec->server_connect = (SERVER_REC *(*) (SERVER_CONNECT_REC *)) + irc_server_connect; + rec->channel_create = + (CHANNEL_REC *(*) (SERVER_REC *, const char *, int)) + irc_channel_create; + rec->query_create = + (QUERY_REC *(*) (const char *, const char *, int)) + irc_query_create; + chat_protocol_register(rec); + g_free(rec); irc_chatnets_init(); irc_servers_init(); diff --git a/src/irc/core/irc-queries.c b/src/irc/core/irc-queries.c index 2204f2c3..87aed832 100644 --- a/src/irc/core/irc-queries.c +++ b/src/irc/core/irc-queries.c @@ -40,21 +40,6 @@ QUERY_REC *irc_query_create(const char *server_tag, return rec; } -static void sig_query_create(QUERY_REC **query, - void *chat_type, const char *server_tag, - const char *nick, void *automatic) -{ - if (chat_protocol_lookup("IRC") != GPOINTER_TO_INT(chat_type)) - return; - - g_return_if_fail(query != NULL); - g_return_if_fail(nick != NULL); - - *query = irc_query_create(server_tag, nick, - GPOINTER_TO_INT(automatic)); - signal_stop(); -} - static void event_privmsg(IRC_SERVER_REC *server, const char *data, const char *nick, const char *address) { @@ -92,14 +77,12 @@ static void event_nick(SERVER_REC *server, const char *data, void irc_queries_init(void) { - signal_add("query create", (SIGNAL_FUNC) sig_query_create); signal_add_last("event privmsg", (SIGNAL_FUNC) event_privmsg); signal_add("event nick", (SIGNAL_FUNC) event_nick); } void irc_queries_deinit(void) { - signal_remove("query create", (SIGNAL_FUNC) sig_query_create); signal_remove("event privmsg", (SIGNAL_FUNC) event_privmsg); signal_remove("event nick", (SIGNAL_FUNC) event_nick); } diff --git a/src/irc/core/irc-servers-setup.c b/src/irc/core/irc-servers-setup.c index ec07420e..536ea310 100644 --- a/src/irc/core/irc-servers-setup.c +++ b/src/irc/core/irc-servers-setup.c @@ -45,23 +45,12 @@ static void sig_server_setup_fill_reconn(IRC_SERVER_CONNECT_REC *conn, conn->max_query_chans = sserver->max_query_chans; } -/* Create server connection record. `address' is required, rest can be NULL */ -static void sig_server_create_conn(SERVER_CONNECT_REC **conn, - IRC_CHATNET_REC *ircnet) +static void sig_server_setup_fill_connect(IRC_SERVER_CONNECT_REC *conn) { - IRC_SERVER_CONNECT_REC *rec; - - g_return_if_fail(conn != NULL); - - if (ircnet != NULL && !IS_IRCNET(ircnet)) + if (!IS_IRC_SERVER_CONNECT(conn)) return; - rec = g_new0(IRC_SERVER_CONNECT_REC, 1); - rec->chat_type = IRC_PROTOCOL; - rec->alternate_nick = g_strdup(settings_get_str("alternate_nick")); - - *conn = (SERVER_CONNECT_REC *) rec; - signal_stop(); + conn->alternate_nick = g_strdup(settings_get_str("alternate_nick")); } static void sig_server_setup_fill_chatnet(IRC_SERVER_CONNECT_REC *conn, @@ -140,27 +129,17 @@ static void init_userinfo(void) } } -static void sig_server_setup_read(SERVER_SETUP_REC **setuprec, - CONFIG_NODE *node, - IRC_CHATNET_REC *chatnet) +static void sig_server_setup_read(IRC_SERVER_SETUP_REC *rec, CONFIG_NODE *node) { - IRC_SERVER_SETUP_REC *rec; - - g_return_if_fail(setuprec != NULL); + g_return_if_fail(rec != NULL); g_return_if_fail(node != NULL); - if (chatnet != NULL && !IS_IRCNET(chatnet)) + if (!IS_IRC_SERVER_SETUP(rec)) return; - rec = g_new0(IRC_SERVER_SETUP_REC, 1); - rec->chat_type = IRC_PROTOCOL; - rec->max_cmds_at_once = config_node_get_int(node, "cmds_max_at_once", 0); rec->cmd_queue_speed = config_node_get_int(node, "cmd_queue_speed", 0); rec->max_query_chans = config_node_get_int(node, "max_query_chans", 0); - - *setuprec = (SERVER_SETUP_REC *) rec; - signal_stop(); } static void sig_server_setup_saved(IRC_SERVER_SETUP_REC *rec, @@ -184,7 +163,7 @@ void irc_servers_setup_init(void) init_userinfo(); signal_add("server setup fill reconn", (SIGNAL_FUNC) sig_server_setup_fill_reconn); - signal_add("server setup connect", (SIGNAL_FUNC) sig_server_create_conn); + signal_add("server setup fill connect", (SIGNAL_FUNC) sig_server_setup_fill_connect); signal_add("server setup fill chatnet", (SIGNAL_FUNC) sig_server_setup_fill_chatnet); signal_add("server setup read", (SIGNAL_FUNC) sig_server_setup_read); signal_add("server setup saved", (SIGNAL_FUNC) sig_server_setup_saved); @@ -193,7 +172,7 @@ void irc_servers_setup_init(void) void irc_servers_setup_deinit(void) { signal_remove("server setup fill reconn", (SIGNAL_FUNC) sig_server_setup_fill_reconn); - signal_remove("server setup connect", (SIGNAL_FUNC) sig_server_create_conn); + signal_remove("server setup fill connect", (SIGNAL_FUNC) sig_server_setup_fill_connect); signal_remove("server setup fill chatnet", (SIGNAL_FUNC) sig_server_setup_fill_chatnet); signal_remove("server setup read", (SIGNAL_FUNC) sig_server_setup_read); signal_remove("server setup saved", (SIGNAL_FUNC) sig_server_setup_saved); diff --git a/src/irc/core/irc-servers.c b/src/irc/core/irc-servers.c index 680f0c68..fd212a7d 100644 --- a/src/irc/core/irc-servers.c +++ b/src/irc/core/irc-servers.c @@ -177,17 +177,6 @@ IRC_SERVER_REC *irc_server_connect(IRC_SERVER_CONNECT_REC *conn) return server; } -static void sig_server_connect(IRC_SERVER_REC **server, - IRC_SERVER_CONNECT_REC *conn) -{ - g_return_if_fail(server != NULL); - if (!IS_IRC_SERVER_CONNECT(conn)) - return; - - *server = irc_server_connect(conn); - signal_stop(); -} - static void sig_connected(IRC_SERVER_REC *server) { if (!IS_IRC_SERVER(server)) @@ -452,7 +441,6 @@ void irc_servers_init(void) cmd_tag = g_timeout_add(500, (GSourceFunc) servers_cmd_timeout, NULL); signal_add("server connect free", (SIGNAL_FUNC) sig_server_connect_free); - signal_add("server connect", (SIGNAL_FUNC) sig_server_connect); signal_add_first("server looking", (SIGNAL_FUNC) sig_server_looking); signal_add_first("server connected", (SIGNAL_FUNC) sig_connected); signal_add_last("server disconnected", (SIGNAL_FUNC) sig_disconnected); @@ -480,7 +468,6 @@ void irc_servers_deinit(void) g_source_remove(cmd_tag); signal_remove("server connect free", (SIGNAL_FUNC) sig_server_connect_free); - signal_remove("server connect", (SIGNAL_FUNC) sig_server_connect); signal_remove("server looking", (SIGNAL_FUNC) sig_server_looking); signal_remove("server connected", (SIGNAL_FUNC) sig_connected); signal_remove("server disconnected", (SIGNAL_FUNC) sig_disconnected); |