mirror of
https://github.com/irssi/irssi.git
synced 2024-12-04 14:46:39 -05:00
Config file: ircnets -> chatnets, added type = "chat protocol" to
chatnet config. Moved reading chatnets to core. Lots of other multiprotocol updates. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@1237 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
parent
513e140bce
commit
be6ba53fa4
52
config
52
config
@ -1,32 +1,27 @@
|
||||
servers = (
|
||||
{ address = "irc.funet.fi"; chatnet = IRCNet; port = 6667; },
|
||||
{ address = "irc.stealth.net"; chatnet = IRCNet; port = 6668; },
|
||||
{ address = "irc.efnet.net"; chatnet = EFNet; port = 6667; },
|
||||
{ address = "irc.undernet.org"; chatnet = Undernet; port = 6667; },
|
||||
{ address = "irc.dal.net"; chatnet = DALNet; port = 6667; },
|
||||
{ address = "irc.openprojects.net"; chatnet = OPN; port = 6667; },
|
||||
{ address = "irc.ptlink.net"; chatnet = PTlink; port = 6667; }
|
||||
{ address = "silc.pspt.fi"; chatnet = SILC; port = 706; }
|
||||
);
|
||||
|
||||
ircnets = {
|
||||
IRCNet = { max_kicks = 4; max_modes = 3; max_msgs = 5; max_whois = 4; };
|
||||
EFNet = { max_kicks = 4; max_modes = 4; max_msgs = 3; };
|
||||
Undernet = { max_kicks = 4; max_modes = 3; max_msgs = 3; };
|
||||
DALNet = { max_kicks = 4; max_modes = 6; max_msgs = 3; };
|
||||
OPN = { max_kicks = 1; max_modes = 6; max_msgs = 100; };
|
||||
PTLink = { max_kicks = 1; max_modes = 6; max_msgs = 100; };
|
||||
chatnets = {
|
||||
IRCNet = { type = "IRC"; max_kicks = 4; max_modes = 3; max_msgs = 5; max_whois = 4; };
|
||||
EFNet = { type = "IRC"; max_kicks = 4; max_modes = 4; max_msgs = 3; };
|
||||
Undernet = { type = "IRC"; max_kicks = 4; max_modes = 3; max_msgs = 3; };
|
||||
DALNet = { type = "IRC"; max_kicks = 4; max_modes = 6; max_msgs = 3; };
|
||||
OPN = { type = "IRC"; max_kicks = 1; max_modes = 6; max_msgs = 100; };
|
||||
PTLink = { type = "IRC"; max_kicks = 1; max_modes = 6; max_msgs = 100; };
|
||||
SILC = { type = "SILC"; };
|
||||
};
|
||||
|
||||
channels = (
|
||||
{
|
||||
name = "#irssi";
|
||||
chatnet = ircnet;
|
||||
autojoin = No;
|
||||
},
|
||||
{
|
||||
name = "#irssi";
|
||||
chatnet = efnet;
|
||||
autojoin = No;
|
||||
}
|
||||
{ name = "#irssi"; chatnet = ircnet; autojoin = No; },
|
||||
{ name = "#irssi"; chatnet = opn; autojoin = No; },
|
||||
{ name = "#silc"; chatnet = silc; autojoin = No; }
|
||||
);
|
||||
|
||||
aliases = {
|
||||
@ -67,24 +62,3 @@ aliases = {
|
||||
SV = "say Irssi $J - http://irssi.org";
|
||||
GOTO = "sb goto";
|
||||
};
|
||||
|
||||
popups = (
|
||||
{ label = "<MULTICOMMA>Whois"; command = "/whois %s"; },
|
||||
{ label = "DCC Send File"; command = "/dcc send %s"; },
|
||||
{ label = "Open DCC Chat"; command = "/dcc chat %s"; },
|
||||
{ label = Query; command = "/query %s"; },
|
||||
{ label = "<MENU><OP>"; command = "Op"; },
|
||||
{ label = "<MULTI>Op"; command = "/op %s"; },
|
||||
{ label = "<MULTI>Deop"; command = "/deop %s"; },
|
||||
{ label = "<MULTI>Voice"; command = "/voice %s"; },
|
||||
{ label = "<MULTI>Devoice"; command = "/devoice %s"; },
|
||||
{ label = "<KICK>Kick"; command = "/kick %s %s"; },
|
||||
{ label = "<MULTI>Ban"; command = "/ban %s"; },
|
||||
{ label = "<KICK>Kick+ban"; command = "/kickban %s %s"; },
|
||||
{ label = "<KICK>Knockout"; command = "/knockout %s %s"; },
|
||||
{ label = "</MENU>"; command = ""; },
|
||||
{ label = "<MENU>"; command = "CTCP"; },
|
||||
{ label = Ping; command = "/ping %s"; },
|
||||
{ label = Version; command = "/ver %s"; },
|
||||
{ label = "</MENU>"; command = ""; }
|
||||
);
|
||||
|
@ -50,8 +50,9 @@ libcore_a_SOURCES = \
|
||||
write-buffer.c
|
||||
|
||||
structure_headers = \
|
||||
chatnet-rec.h \
|
||||
channel-rec.h \
|
||||
channel-setup-rec.h \
|
||||
chatnet-rec.h \
|
||||
query-rec.h \
|
||||
server-rec.h \
|
||||
server-setup-rec.h \
|
||||
|
12
src/core/channel-setup-rec.h
Normal file
12
src/core/channel-setup-rec.h
Normal file
@ -0,0 +1,12 @@
|
||||
int type; /* module_get_uniq_id("CHANNEL SETUP", 0) */
|
||||
int chat_type; /* chat_protocol_lookup(xx) */
|
||||
|
||||
char *name;
|
||||
char *chatnet;
|
||||
char *password;
|
||||
|
||||
char *botmasks;
|
||||
char *autosendcmd;
|
||||
|
||||
unsigned int autojoin:1;
|
||||
GHashTable *module_data;
|
@ -23,49 +23,13 @@
|
||||
#include "lib-config/iconfig.h"
|
||||
#include "settings.h"
|
||||
|
||||
#include "channels.h"
|
||||
#include "channels-setup.h"
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "servers-setup.h"
|
||||
#include "channels-setup.h"
|
||||
|
||||
GSList *setupchannels;
|
||||
|
||||
static CHANNEL_SETUP_REC *channel_setup_read(CONFIG_NODE *node)
|
||||
{
|
||||
CHANNEL_SETUP_REC *rec;
|
||||
char *channel, *password, *botmasks, *autosendcmd;
|
||||
|
||||
g_return_val_if_fail(node != NULL, NULL);
|
||||
|
||||
channel = config_node_get_str(node, "name", NULL);
|
||||
if (channel == NULL) {
|
||||
/* missing information.. */
|
||||
return NULL;
|
||||
}
|
||||
|
||||
password = config_node_get_str(node, "password", NULL);
|
||||
botmasks = config_node_get_str(node, "botmasks", NULL);
|
||||
autosendcmd = config_node_get_str(node, "autosendcmd", NULL);
|
||||
|
||||
rec = g_new(CHANNEL_SETUP_REC, 1);
|
||||
rec->autojoin = config_node_get_bool(node, "autojoin", FALSE);
|
||||
rec->name = g_strdup(channel);
|
||||
rec->chatnet = g_strdup(config_node_get_str(node, "chatnet", NULL));
|
||||
if (rec->chatnet == NULL) /* FIXME: remove this after .98... */ {
|
||||
rec->chatnet = g_strdup(config_node_get_str(node, "ircnet", NULL));
|
||||
if (rec->chatnet != NULL) {
|
||||
iconfig_node_set_str(node, "chatnet", rec->chatnet);
|
||||
iconfig_node_set_str(node, "ircnet", NULL);
|
||||
}
|
||||
}
|
||||
rec->password = (password == NULL || *password == '\0') ? NULL : g_strdup(password);
|
||||
rec->botmasks = (botmasks == NULL || *botmasks == '\0') ? NULL : g_strdup(botmasks);
|
||||
rec->autosendcmd = (autosendcmd == NULL || *autosendcmd == '\0') ? NULL : g_strdup(autosendcmd);
|
||||
|
||||
setupchannels = g_slist_append(setupchannels, rec);
|
||||
signal_emit("channel setup created", 2, rec, node);
|
||||
return rec;
|
||||
}
|
||||
|
||||
static void channel_setup_save(CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
CONFIG_NODE *parentnode, *node;
|
||||
@ -88,15 +52,7 @@ static void channel_setup_save(CHANNEL_SETUP_REC *channel)
|
||||
iconfig_node_set_str(node, "autosendcmd", channel->autosendcmd);
|
||||
}
|
||||
|
||||
static void channel_config_remove(CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
CONFIG_NODE *node;
|
||||
|
||||
node = iconfig_node_traverse("channels", FALSE);
|
||||
if (node != NULL) iconfig_node_list_remove(node, g_slist_index(setupchannels, channel));
|
||||
}
|
||||
|
||||
void channels_setup_create(CHANNEL_SETUP_REC *channel)
|
||||
void channel_setup_create(CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
if (g_slist_find(setupchannels, channel) == NULL)
|
||||
setupchannels = g_slist_append(setupchannels, channel);
|
||||
@ -105,28 +61,37 @@ void channels_setup_create(CHANNEL_SETUP_REC *channel)
|
||||
signal_emit("channel setup created", 1, channel);
|
||||
}
|
||||
|
||||
static void channels_setup_destroy_rec(CHANNEL_SETUP_REC *channel)
|
||||
static void channel_config_remove(CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
CONFIG_NODE *node;
|
||||
|
||||
node = iconfig_node_traverse("channels", FALSE);
|
||||
if (node != NULL) iconfig_node_list_remove(node, g_slist_index(setupchannels, channel));
|
||||
}
|
||||
|
||||
static void channel_setup_destroy(CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
g_return_if_fail(channel != NULL);
|
||||
|
||||
setupchannels = g_slist_remove(setupchannels, channel);
|
||||
signal_emit("channel setup destroyed", 1, channel);
|
||||
|
||||
g_free(channel->name);
|
||||
g_free_not_null(channel->chatnet);
|
||||
g_free_not_null(channel->password);
|
||||
g_free_not_null(channel->botmasks);
|
||||
g_free_not_null(channel->autosendcmd);
|
||||
g_free(channel->name);
|
||||
g_free(channel);
|
||||
}
|
||||
|
||||
void channels_setup_destroy(CHANNEL_SETUP_REC *channel)
|
||||
void channel_setup_remove(CHANNEL_SETUP_REC *channel)
|
||||
{
|
||||
channel_config_remove(channel);
|
||||
channels_setup_destroy_rec(channel);
|
||||
channel_setup_destroy(channel);
|
||||
}
|
||||
|
||||
CHANNEL_SETUP_REC *channels_setup_find(const char *channel, const char *chatnet)
|
||||
CHANNEL_SETUP_REC *channel_setup_find(const char *channel,
|
||||
const char *chatnet)
|
||||
{
|
||||
GSList *tmp;
|
||||
|
||||
@ -143,13 +108,52 @@ CHANNEL_SETUP_REC *channels_setup_find(const char *channel, const char *chatnet)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static CHANNEL_SETUP_REC *channel_setup_read(CONFIG_NODE *node)
|
||||
{
|
||||
CHANNEL_SETUP_REC *rec;
|
||||
CHATNET_REC *chatnetrec;
|
||||
char *channel, *chatnet;
|
||||
|
||||
g_return_val_if_fail(node != NULL, NULL);
|
||||
|
||||
channel = config_node_get_str(node, "name", NULL);
|
||||
chatnet = config_node_get_str(node, "chatnet", NULL);
|
||||
if (chatnet == NULL) /* FIXME: remove this after .98... */ {
|
||||
chatnet = g_strdup(config_node_get_str(node, "ircnet", NULL));
|
||||
if (chatnet != NULL) {
|
||||
iconfig_node_set_str(node, "chatnet", chatnet);
|
||||
iconfig_node_set_str(node, "ircnet", NULL);
|
||||
}
|
||||
}
|
||||
|
||||
chatnetrec = chatnet == NULL ? NULL : chatnet_find(chatnet);
|
||||
if (channel == NULL || chatnetrec == NULL) {
|
||||
/* missing information.. */
|
||||
return NULL;
|
||||
}
|
||||
|
||||
rec = CHAT_PROTOCOL(chatnetrec)->create_channel_setup();
|
||||
rec->type = module_get_uniq_id("CHANNEL SETUP", 0);
|
||||
rec->chat_type = CHAT_PROTOCOL(chatnetrec)->id;
|
||||
rec->autojoin = config_node_get_bool(node, "autojoin", FALSE);
|
||||
rec->name = g_strdup(channel);
|
||||
rec->chatnet = g_strdup(chatnetrec != NULL ? chatnetrec->name : chatnet);
|
||||
rec->password = g_strdup(config_node_get_str(node, "password", NULL));
|
||||
rec->botmasks = g_strdup(config_node_get_str(node, "botmasks", NULL));
|
||||
rec->autosendcmd = g_strdup(config_node_get_str(node, "autosendcmd", NULL));
|
||||
|
||||
setupchannels = g_slist_append(setupchannels, rec);
|
||||
signal_emit("channel setup created", 2, rec, node);
|
||||
return rec;
|
||||
}
|
||||
|
||||
static void channels_read_config(void)
|
||||
{
|
||||
CONFIG_NODE *node;
|
||||
GSList *tmp;
|
||||
|
||||
while (setupchannels != NULL)
|
||||
channels_setup_destroy_rec(setupchannels->data);
|
||||
channel_setup_destroy(setupchannels->data);
|
||||
|
||||
/* Read channels */
|
||||
node = iconfig_node_traverse("channels", FALSE);
|
||||
@ -161,6 +165,7 @@ static void channels_read_config(void)
|
||||
|
||||
void channels_setup_init(void)
|
||||
{
|
||||
setupchannels = NULL;
|
||||
source_host_ok = FALSE;
|
||||
|
||||
signal_add("setup reread", (SIGNAL_FUNC) channels_read_config);
|
||||
@ -170,7 +175,7 @@ void channels_setup_init(void)
|
||||
void channels_setup_deinit(void)
|
||||
{
|
||||
while (setupchannels != NULL)
|
||||
channels_setup_destroy(setupchannels->data);
|
||||
channel_setup_destroy(setupchannels->data);
|
||||
|
||||
signal_remove("setup reread", (SIGNAL_FUNC) channels_read_config);
|
||||
signal_remove("irssi init read settings", (SIGNAL_FUNC) channels_read_config);
|
||||
|
@ -3,16 +3,14 @@
|
||||
|
||||
#include "modules.h"
|
||||
|
||||
#define CHANNEL_SETUP(server) \
|
||||
MODULE_CHECK_CAST(server, CHANNEL_SETUP_REC, type, "CHANNEL SETUP")
|
||||
|
||||
#define IS_CHANNEL_SETUP(server) \
|
||||
(CHANNEL_SETUP(server) ? TRUE : FALSE)
|
||||
|
||||
struct _CHANNEL_SETUP_REC {
|
||||
char *name;
|
||||
char *chatnet;
|
||||
char *password;
|
||||
|
||||
char *botmasks;
|
||||
char *autosendcmd;
|
||||
|
||||
unsigned int autojoin:1;
|
||||
GHashTable *module_data;
|
||||
#include "channel-setup-rec.h"
|
||||
};
|
||||
|
||||
extern GSList *setupchannels;
|
||||
@ -20,10 +18,10 @@ extern GSList *setupchannels;
|
||||
void channels_setup_init(void);
|
||||
void channels_setup_deinit(void);
|
||||
|
||||
void channels_setup_create(CHANNEL_SETUP_REC *channel);
|
||||
void channels_setup_destroy(CHANNEL_SETUP_REC *channel);
|
||||
void channel_setup_create(CHANNEL_SETUP_REC *channel);
|
||||
void channel_setup_remove(CHANNEL_SETUP_REC *channel);
|
||||
|
||||
CHANNEL_SETUP_REC *channels_setup_find(const char *channel,
|
||||
CHANNEL_SETUP_REC *channel_setup_find(const char *channel,
|
||||
const char *chatnet);
|
||||
|
||||
#define channel_chatnet_match(rec, chatnet) \
|
||||
|
@ -30,21 +30,6 @@
|
||||
|
||||
GSList *channels; /* List of all channels */
|
||||
|
||||
/* Create a new channel */
|
||||
CHANNEL_REC *channel_create(int chat_type, SERVER_REC *server,
|
||||
const char *name, int automatic)
|
||||
{
|
||||
CHANNEL_REC *channel;
|
||||
|
||||
g_return_val_if_fail(server == NULL || IS_SERVER(server), NULL);
|
||||
g_return_val_if_fail(name != NULL, NULL);
|
||||
|
||||
channel = NULL;
|
||||
signal_emit("channel create", 5, &channel, GINT_TO_POINTER(chat_type),
|
||||
server, name, GINT_TO_POINTER(automatic));
|
||||
return channel;
|
||||
}
|
||||
|
||||
void channel_init(CHANNEL_REC *channel, int automatic)
|
||||
{
|
||||
g_return_if_fail(channel != NULL);
|
||||
@ -173,7 +158,7 @@ void channel_send_autocommands(CHANNEL_REC *channel)
|
||||
|
||||
g_return_if_fail(IS_CHANNEL(channel));
|
||||
|
||||
rec = channels_setup_find(channel->name, channel->server->connrec->chatnet);
|
||||
rec = channel_setup_find(channel->name, channel->server->connrec->chatnet);
|
||||
if (rec == NULL || rec->autosendcmd == NULL || !*rec->autosendcmd)
|
||||
return;
|
||||
|
||||
|
@ -18,10 +18,6 @@ struct _CHANNEL_REC {
|
||||
|
||||
extern GSList *channels;
|
||||
|
||||
/* Create a new channel */
|
||||
CHANNEL_REC *channel_create(int chat_type, SERVER_REC *server,
|
||||
const char *name, int automatic);
|
||||
|
||||
/* Create new channel record */
|
||||
void channel_init(CHANNEL_REC *channel, int automatic);
|
||||
void channel_destroy(CHANNEL_REC *channel);
|
||||
|
@ -19,12 +19,19 @@
|
||||
*/
|
||||
|
||||
#include "module.h"
|
||||
#include "modules.h"
|
||||
#include "signals.h"
|
||||
#include "chat-protocols.h"
|
||||
|
||||
static int id_counter;
|
||||
#include "chatnets.h"
|
||||
#include "servers.h"
|
||||
#include "servers-setup.h"
|
||||
#include "channels-setup.h"
|
||||
|
||||
GSList *chat_protocols;
|
||||
|
||||
static CHAT_PROTOCOL_REC *default_proto;
|
||||
|
||||
void *chat_protocol_check_cast(void *object, int type_pos, const char *id)
|
||||
{
|
||||
return object == NULL ||
|
||||
@ -75,18 +82,48 @@ CHAT_PROTOCOL_REC *chat_protocol_find_id(int id)
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Register new chat protocol. */
|
||||
void chat_protocol_register(CHAT_PROTOCOL_REC *rec)
|
||||
CHAT_PROTOCOL_REC *chat_protocol_find_net(GHashTable *optlist)
|
||||
{
|
||||
g_return_if_fail(rec != NULL);
|
||||
GSList *tmp;
|
||||
|
||||
if (chat_protocol_find(rec->name) != NULL)
|
||||
return;
|
||||
g_return_val_if_fail(optlist != NULL, NULL);
|
||||
|
||||
rec->id = ++id_counter;
|
||||
chat_protocols = g_slist_append(chat_protocols, rec);
|
||||
for (tmp = chat_protocols; tmp != NULL; tmp = tmp->next) {
|
||||
CHAT_PROTOCOL_REC *rec = tmp->data;
|
||||
|
||||
signal_emit("chat protocol created", 1, rec);
|
||||
if (g_hash_table_lookup(optlist, rec->chatnet) != NULL)
|
||||
return rec;
|
||||
}
|
||||
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Register new chat protocol. */
|
||||
CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec)
|
||||
{
|
||||
CHAT_PROTOCOL_REC *newrec;
|
||||
|
||||
g_return_val_if_fail(rec != NULL, NULL);
|
||||
|
||||
newrec = chat_protocol_find(rec->name);
|
||||
if (newrec == NULL)
|
||||
newrec = g_new0(CHAT_PROTOCOL_REC, 1);
|
||||
else if (rec->fullname != NULL) {
|
||||
/* already registered */
|
||||
return newrec;
|
||||
}
|
||||
|
||||
memcpy(newrec, rec, sizeof(CHAT_PROTOCOL_REC));
|
||||
newrec->id = module_get_uniq_id_str("PROTOCOL", rec->name);
|
||||
newrec->name = g_strdup(rec->name);
|
||||
|
||||
chat_protocols = g_slist_append(chat_protocols, newrec);
|
||||
|
||||
if (default_proto == NULL)
|
||||
chat_protocol_set_default(newrec);
|
||||
|
||||
signal_emit("chat protocol created", 1, newrec);
|
||||
return newrec;
|
||||
}
|
||||
|
||||
static void chat_protocol_destroy(CHAT_PROTOCOL_REC *rec)
|
||||
@ -94,7 +131,15 @@ static void chat_protocol_destroy(CHAT_PROTOCOL_REC *rec)
|
||||
g_return_if_fail(rec != NULL);
|
||||
|
||||
chat_protocols = g_slist_remove(chat_protocols, rec);
|
||||
|
||||
if (default_proto == rec) {
|
||||
chat_protocol_set_default(chat_protocols == NULL ? NULL :
|
||||
chat_protocols->data);
|
||||
}
|
||||
|
||||
signal_emit("chat protocol destroyed", 1, rec);
|
||||
|
||||
g_free(rec->name);
|
||||
g_free(rec);
|
||||
}
|
||||
|
||||
@ -109,9 +154,64 @@ void chat_protocol_unregister(const char *name)
|
||||
if (rec != NULL) chat_protocol_destroy(rec);
|
||||
}
|
||||
|
||||
/* Default chat protocol to use */
|
||||
void chat_protocol_set_default(CHAT_PROTOCOL_REC *rec)
|
||||
{
|
||||
default_proto = rec;
|
||||
}
|
||||
|
||||
CHAT_PROTOCOL_REC *chat_protocol_get_default(void)
|
||||
{
|
||||
return default_proto;
|
||||
}
|
||||
|
||||
static CHATNET_REC *create_chatnet(void)
|
||||
{
|
||||
return g_new0(CHATNET_REC, 1);
|
||||
}
|
||||
|
||||
static SERVER_SETUP_REC *create_server_setup(void)
|
||||
{
|
||||
return g_new0(SERVER_SETUP_REC, 1);
|
||||
}
|
||||
|
||||
static CHANNEL_SETUP_REC *create_channel_setup(void)
|
||||
{
|
||||
return g_new0(CHANNEL_SETUP_REC, 1);
|
||||
}
|
||||
|
||||
static SERVER_CONNECT_REC *create_server_connect(void)
|
||||
{
|
||||
return g_new0(SERVER_CONNECT_REC, 1);
|
||||
}
|
||||
|
||||
/* Return "unknown chat protocol" record. Used when protocol name is
|
||||
specified but it isn't registered yet. */
|
||||
CHAT_PROTOCOL_REC *chat_protocol_get_unknown(const char *name)
|
||||
{
|
||||
CHAT_PROTOCOL_REC *rec, *newrec;
|
||||
|
||||
g_return_val_if_fail(name != NULL, NULL);
|
||||
|
||||
rec = chat_protocol_find(name);
|
||||
if (rec != NULL)
|
||||
return rec;
|
||||
|
||||
rec = g_new0(CHAT_PROTOCOL_REC, 1);
|
||||
rec->name = (char *) name;
|
||||
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;
|
||||
|
||||
newrec = chat_protocol_register(rec);
|
||||
g_free(rec);
|
||||
return newrec;
|
||||
}
|
||||
|
||||
void chat_protocols_init(void)
|
||||
{
|
||||
id_counter = 0;
|
||||
default_proto = NULL;
|
||||
chat_protocols = NULL;
|
||||
}
|
||||
|
||||
|
@ -7,6 +7,15 @@ typedef struct {
|
||||
char *name;
|
||||
char *fullname;
|
||||
char *chatnet;
|
||||
|
||||
CHATNET_REC *(*create_chatnet) (void);
|
||||
SERVER_SETUP_REC *(*create_server_setup) (void);
|
||||
CHANNEL_SETUP_REC *(*create_channel_setup) (void);
|
||||
SERVER_CONNECT_REC *(*create_server_connect) (void);
|
||||
|
||||
SERVER_REC *(*server_connect) (SERVER_CONNECT_REC *);
|
||||
CHANNEL_REC *(*channel_create) (SERVER_REC *, const char *, int);
|
||||
QUERY_REC *(*query_create) (const char *, const char *, int);
|
||||
} CHAT_PROTOCOL_REC;
|
||||
|
||||
extern GSList *chat_protocols;
|
||||
@ -16,8 +25,12 @@ extern GSList *chat_protocols;
|
||||
offsetof(cast, type_field), id))
|
||||
void *chat_protocol_check_cast(void *object, int type_pos, const char *id);
|
||||
|
||||
#define CHAT_PROTOCOL(object) \
|
||||
((object) == NULL ? chat_protocol_get_default() : \
|
||||
chat_protocol_find_id((object)->chat_type))
|
||||
|
||||
/* Register new chat protocol. */
|
||||
void chat_protocol_register(CHAT_PROTOCOL_REC *rec);
|
||||
CHAT_PROTOCOL_REC *chat_protocol_register(CHAT_PROTOCOL_REC *rec);
|
||||
|
||||
/* Unregister chat protocol. */
|
||||
void chat_protocol_unregister(const char *name);
|
||||
@ -26,6 +39,15 @@ void chat_protocol_unregister(const char *name);
|
||||
int chat_protocol_lookup(const char *name);
|
||||
CHAT_PROTOCOL_REC *chat_protocol_find(const char *name);
|
||||
CHAT_PROTOCOL_REC *chat_protocol_find_id(int id);
|
||||
CHAT_PROTOCOL_REC *chat_protocol_find_net(GHashTable *optlist);
|
||||
|
||||
/* Default chat protocol to use */
|
||||
void chat_protocol_set_default(CHAT_PROTOCOL_REC *rec);
|
||||
CHAT_PROTOCOL_REC *chat_protocol_get_default(void);
|
||||
|
||||
/* Return "unknown chat protocol" record. Used when protocol name is
|
||||
specified but it isn't registered yet. */
|
||||
CHAT_PROTOCOL_REC *chat_protocol_get_unknown(const char *name);
|
||||
|
||||
void chat_protocols_init(void);
|
||||
void chat_protocols_deinit(void);
|
||||
|
@ -25,42 +25,36 @@
|
||||
#include "lib-config/iconfig.h"
|
||||
#include "settings.h"
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "servers.h"
|
||||
|
||||
GSList *chatnets; /* list of available chat networks */
|
||||
|
||||
void chatnet_read(CHATNET_REC *chatnet, CONFIG_NODE *node)
|
||||
static void chatnet_config_save(CHATNET_REC *chatnet)
|
||||
{
|
||||
g_return_if_fail(chatnet != NULL);
|
||||
g_return_if_fail(node != NULL);
|
||||
g_return_if_fail(node->key != NULL);
|
||||
|
||||
chatnet->type = module_get_uniq_id("CHATNET", 0);
|
||||
chatnet->name = g_strdup(node->key);
|
||||
chatnet->nick = g_strdup(config_node_get_str(node, "nick", NULL));
|
||||
chatnet->username = g_strdup(config_node_get_str(node, "username", NULL));
|
||||
chatnet->realname = g_strdup(config_node_get_str(node, "realname", NULL));
|
||||
chatnet->own_host = g_strdup(config_node_get_str(node, "host", NULL));
|
||||
chatnet->autosendcmd = g_strdup(config_node_get_str(node, "autosendcmd", NULL));
|
||||
|
||||
chatnets = g_slist_append(chatnets, chatnet);
|
||||
}
|
||||
|
||||
CONFIG_NODE *chatnet_save(CHATNET_REC *chatnet, CONFIG_NODE *node)
|
||||
{
|
||||
g_return_val_if_fail(node != NULL, NULL);
|
||||
g_return_val_if_fail(chatnet != NULL, NULL);
|
||||
CONFIG_NODE *node;
|
||||
|
||||
node = iconfig_node_traverse("chatnets", TRUE);
|
||||
node = config_node_section(node, chatnet->name, NODE_TYPE_BLOCK);
|
||||
iconfig_node_clear(node);
|
||||
|
||||
iconfig_node_set_str(node, "type", chat_protocol_find_id(chatnet->chat_type)->name);
|
||||
iconfig_node_set_str(node, "nick", chatnet->nick);
|
||||
iconfig_node_set_str(node, "username", chatnet->username);
|
||||
iconfig_node_set_str(node, "realname", chatnet->realname);
|
||||
iconfig_node_set_str(node, "host", chatnet->own_host);
|
||||
iconfig_node_set_str(node, "autosendcmd", chatnet->autosendcmd);
|
||||
return node;
|
||||
|
||||
signal_emit("chatnet saved", 2, chatnet, node);
|
||||
}
|
||||
|
||||
static void chatnet_config_remove(CHATNET_REC *chatnet)
|
||||
{
|
||||
CONFIG_NODE *node;
|
||||
|
||||
node = iconfig_node_traverse("chatnets", FALSE);
|
||||
if (node != NULL) iconfig_node_set_str(node, chatnet->name, NULL);
|
||||
}
|
||||
|
||||
void chatnet_create(CHATNET_REC *chatnet)
|
||||
@ -71,6 +65,7 @@ void chatnet_create(CHATNET_REC *chatnet)
|
||||
if (g_slist_find(chatnets, chatnet) == NULL)
|
||||
chatnets = g_slist_append(chatnets, chatnet);
|
||||
|
||||
chatnet_config_save(chatnet);
|
||||
signal_emit("chatnet created", 1, chatnet);
|
||||
}
|
||||
|
||||
@ -79,6 +74,8 @@ void chatnet_remove(CHATNET_REC *chatnet)
|
||||
g_return_if_fail(IS_CHATNET(chatnet));
|
||||
|
||||
signal_emit("chatnet removed", 1, chatnet);
|
||||
|
||||
chatnet_config_remove(chatnet);
|
||||
chatnet_destroy(chatnet);
|
||||
}
|
||||
|
||||
@ -89,16 +86,16 @@ void chatnet_destroy(CHATNET_REC *chatnet)
|
||||
chatnets = g_slist_remove(chatnets, chatnet);
|
||||
signal_emit("chatnet destroyed", 1, chatnet);
|
||||
|
||||
g_free(chatnet->name);
|
||||
g_free_not_null(chatnet->nick);
|
||||
g_free_not_null(chatnet->username);
|
||||
g_free_not_null(chatnet->realname);
|
||||
g_free_not_null(chatnet->own_host);
|
||||
g_free_not_null(chatnet->autosendcmd);
|
||||
g_free(chatnet->name);
|
||||
g_free(chatnet);
|
||||
}
|
||||
|
||||
/* Find the irc network by name */
|
||||
/* Find the chat network by name */
|
||||
CHATNET_REC *chatnet_find(const char *name)
|
||||
{
|
||||
GSList *tmp;
|
||||
@ -129,17 +126,78 @@ static void sig_connected(SERVER_REC *server)
|
||||
eval_special_string(rec->autosendcmd, "", server, NULL);
|
||||
}
|
||||
|
||||
static void chatnet_read(CONFIG_NODE *node)
|
||||
{
|
||||
CHAT_PROTOCOL_REC *proto;
|
||||
CHATNET_REC *rec;
|
||||
char *type;
|
||||
|
||||
if (node == NULL || node->key == NULL)
|
||||
return;
|
||||
|
||||
type = config_node_get_str(node, "type", NULL);
|
||||
proto = type == NULL ? NULL : chat_protocol_find(type);
|
||||
if (proto == NULL) {
|
||||
proto = type == NULL ? chat_protocol_get_default() :
|
||||
chat_protocol_get_unknown(type);
|
||||
}
|
||||
|
||||
if (type == NULL)
|
||||
iconfig_node_set_str(node, "type", proto->name);
|
||||
|
||||
rec = proto->create_chatnet();
|
||||
rec->type = module_get_uniq_id("CHATNET", 0);
|
||||
rec->chat_type = proto->id;
|
||||
rec->name = g_strdup(node->key);
|
||||
rec->nick = g_strdup(config_node_get_str(node, "nick", NULL));
|
||||
rec->username = g_strdup(config_node_get_str(node, "username", NULL));
|
||||
rec->realname = g_strdup(config_node_get_str(node, "realname", NULL));
|
||||
rec->own_host = g_strdup(config_node_get_str(node, "host", NULL));
|
||||
rec->autosendcmd = g_strdup(config_node_get_str(node, "autosendcmd", NULL));
|
||||
|
||||
chatnets = g_slist_append(chatnets, rec);
|
||||
signal_emit("chatnet read", 2, rec, node);
|
||||
}
|
||||
|
||||
static void read_chatnets(void)
|
||||
{
|
||||
CONFIG_NODE *node;
|
||||
|
||||
while (chatnets != NULL)
|
||||
chatnet_destroy(chatnets->data);
|
||||
|
||||
node = iconfig_node_traverse("chatnets", FALSE);
|
||||
if (node == NULL) {
|
||||
/* FIXME: remove after .98 */
|
||||
node = iconfig_node_traverse("ircnets", FALSE);
|
||||
if (node != NULL) {
|
||||
/* very dirty method - doesn't update hashtables
|
||||
but this will do temporarily.. */
|
||||
g_free(node->key);
|
||||
node->key = g_strdup("chatnets");
|
||||
}
|
||||
}
|
||||
|
||||
if (node != NULL)
|
||||
g_slist_foreach(node->value, (GFunc) chatnet_read, NULL);
|
||||
}
|
||||
|
||||
void chatnets_init(void)
|
||||
{
|
||||
chatnets = NULL;
|
||||
|
||||
signal_add("event connected", (SIGNAL_FUNC) sig_connected);
|
||||
signal_add("setup reread", (SIGNAL_FUNC) read_chatnets);
|
||||
signal_add_first("irssi init read settings", (SIGNAL_FUNC) read_chatnets);
|
||||
}
|
||||
|
||||
void chatnets_deinit(void)
|
||||
{
|
||||
while (chatnets != NULL)
|
||||
chatnet_destroy(chatnets->data);
|
||||
module_uniq_destroy("CHATNET");
|
||||
|
||||
signal_remove("event connected", (SIGNAL_FUNC) sig_connected);
|
||||
module_uniq_destroy("CHATNET");
|
||||
signal_remove("setup reread", (SIGNAL_FUNC) read_chatnets);
|
||||
signal_remove("irssi init read settings", (SIGNAL_FUNC) read_chatnets);
|
||||
}
|
||||
|
@ -16,10 +16,6 @@ struct _CHATNET_REC {
|
||||
|
||||
extern GSList *chatnets; /* list of available chat networks */
|
||||
|
||||
/* read/save to configuration file */
|
||||
void chatnet_read(CHATNET_REC *chatnet, CONFIG_NODE *node);
|
||||
CONFIG_NODE *chatnet_save(CHATNET_REC *chatnet, CONFIG_NODE *parentnode);
|
||||
|
||||
/* add the chatnet to chat networks list */
|
||||
void chatnet_create(CHATNET_REC *chatnet);
|
||||
/* remove the chatnet from chat networks list */
|
||||
@ -27,7 +23,7 @@ void chatnet_remove(CHATNET_REC *chatnet);
|
||||
/* destroy the chatnet structure. doesn't remove from config file */
|
||||
void chatnet_destroy(CHATNET_REC *chatnet);
|
||||
|
||||
/* Find the irc network by name */
|
||||
/* Find the chat network by name */
|
||||
CHATNET_REC *chatnet_find(const char *name);
|
||||
|
||||
void chatnets_init(void);
|
||||
|
@ -224,7 +224,7 @@ void log_write_rec(LOG_REC *log, const char *str, int level)
|
||||
}
|
||||
|
||||
LOG_ITEM_REC *log_item_find(LOG_REC *log, int type, const char *item,
|
||||
SERVER_REC *server)
|
||||
const char *servertag)
|
||||
{
|
||||
GSList *tmp;
|
||||
|
||||
@ -235,8 +235,8 @@ LOG_ITEM_REC *log_item_find(LOG_REC *log, int type, const char *item,
|
||||
LOG_ITEM_REC *rec = tmp->data;
|
||||
|
||||
if (rec->type == type && g_strcasecmp(rec->name, item) == 0 &&
|
||||
(rec->servertag == NULL || (server != NULL &&
|
||||
g_strcasecmp(rec->servertag, server->tag) == 0)))
|
||||
(rec->servertag == NULL || (servertag != NULL &&
|
||||
g_strcasecmp(rec->servertag, servertag) == 0)))
|
||||
return rec;
|
||||
}
|
||||
|
||||
@ -268,8 +268,9 @@ void log_file_write(SERVER_REC *server, const char *item, int level,
|
||||
|
||||
if (rec->items == NULL)
|
||||
fallbacks = g_slist_append(fallbacks, rec);
|
||||
else if (item != NULL && log_item_find(rec, LOG_ITEM_TARGET,
|
||||
item, server) != NULL)
|
||||
else if (item != NULL &&
|
||||
log_item_find(rec, LOG_ITEM_TARGET, item,
|
||||
server->tag) != NULL)
|
||||
log_write_rec(rec, str, level);
|
||||
}
|
||||
|
||||
@ -367,20 +368,20 @@ LOG_REC *log_create_rec(const char *fname, int level)
|
||||
}
|
||||
|
||||
void log_item_add(LOG_REC *log, int type, const char *name,
|
||||
SERVER_REC *server)
|
||||
const char *servertag)
|
||||
{
|
||||
LOG_ITEM_REC *rec;
|
||||
|
||||
g_return_if_fail(log != NULL);
|
||||
g_return_if_fail(name != NULL);
|
||||
|
||||
if (log_item_find(log, type, name, server))
|
||||
if (log_item_find(log, type, name, servertag))
|
||||
return;
|
||||
|
||||
rec = g_new0(LOG_ITEM_REC, 1);
|
||||
rec->type = type;
|
||||
rec->name = g_strdup(name);
|
||||
rec->servertag = server == NULL ? NULL : g_strdup(server->tag);
|
||||
rec->servertag = g_strdup(servertag);
|
||||
|
||||
log->items = g_slist_append(log->items, rec);
|
||||
}
|
||||
|
@ -38,10 +38,10 @@ void log_close(LOG_REC *log);
|
||||
LOG_REC *log_find(const char *fname);
|
||||
|
||||
void log_item_add(LOG_REC *log, int type, const char *name,
|
||||
SERVER_REC *server);
|
||||
const char *servertag);
|
||||
void log_item_destroy(LOG_REC *log, LOG_ITEM_REC *item);
|
||||
LOG_ITEM_REC *log_item_find(LOG_REC *log, int type, const char *item,
|
||||
SERVER_REC *server);
|
||||
const char *servertag);
|
||||
|
||||
void log_file_write(SERVER_REC *server, const char *item, int level,
|
||||
const char *str, int no_fallbacks);
|
||||
|
@ -27,20 +27,6 @@
|
||||
|
||||
GSList *queries;
|
||||
|
||||
/* Create a new query */
|
||||
QUERY_REC *query_create(int chat_type, const char *server_tag,
|
||||
const char *nick, int automatic)
|
||||
{
|
||||
QUERY_REC *query;
|
||||
|
||||
g_return_val_if_fail(nick != NULL, NULL);
|
||||
|
||||
query = NULL;
|
||||
signal_emit("query create", 5, &query, GINT_TO_POINTER(chat_type),
|
||||
server_tag, nick, GINT_TO_POINTER(automatic));
|
||||
return query;
|
||||
}
|
||||
|
||||
void query_init(QUERY_REC *query, int automatic)
|
||||
{
|
||||
g_return_if_fail(query != NULL);
|
||||
|
@ -21,10 +21,6 @@ extern GSList *queries;
|
||||
void query_init(QUERY_REC *query, int automatic);
|
||||
void query_destroy(QUERY_REC *query);
|
||||
|
||||
/* Create a new query */
|
||||
QUERY_REC *query_create(int chat_type, const char *server_tag,
|
||||
const char *nick, int automatic);
|
||||
|
||||
/* Find query by name, if `server' is NULL, search from all servers */
|
||||
QUERY_REC *query_find(SERVER_REC *server, const char *nick);
|
||||
|
||||
|
@ -24,9 +24,10 @@
|
||||
#include "lib-config/iconfig.h"
|
||||
#include "settings.h"
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "servers.h"
|
||||
#include "servers-setup.h"
|
||||
#include "chatnets.h"
|
||||
|
||||
GSList *setupservers;
|
||||
|
||||
@ -164,9 +165,10 @@ static void server_setup_fill_chatnet(SERVER_CONNECT_REC *conn,
|
||||
}
|
||||
|
||||
static SERVER_CONNECT_REC *
|
||||
create_addr_conn(const char *address, int port,
|
||||
create_addr_conn(int chat_type, const char *address, int port,
|
||||
const char *password, const char *nick)
|
||||
{
|
||||
CHAT_PROTOCOL_REC *proto;
|
||||
SERVER_CONNECT_REC *conn;
|
||||
SERVER_SETUP_REC *sserver;
|
||||
CHATNET_REC *chatnet;
|
||||
@ -174,19 +176,20 @@ create_addr_conn(const char *address, int port,
|
||||
g_return_val_if_fail(address != NULL, NULL);
|
||||
|
||||
sserver = server_setup_find(address, port);
|
||||
chatnet = sserver == NULL || sserver->chatnet == NULL ? NULL :
|
||||
chatnet_find(sserver->chatnet);
|
||||
conn = NULL;
|
||||
signal_emit("server setup connect", 2, &conn, chatnet);
|
||||
if (conn == NULL) {
|
||||
/* no chat protocol wanted this server? */
|
||||
return NULL;
|
||||
}
|
||||
if (sserver != NULL) chat_type = sserver->chat_type;
|
||||
|
||||
proto = chat_type >= 0 ? chat_protocol_find_id(chat_type) :
|
||||
chat_protocol_get_default();
|
||||
|
||||
conn = proto->create_server_connect();
|
||||
conn->chat_type = proto->id;
|
||||
|
||||
/* fill in the defaults */
|
||||
server_setup_fill(conn, address, port);
|
||||
|
||||
/* fill the rest from chat network settings */
|
||||
chatnet = sserver == NULL || sserver->chatnet == NULL ? NULL :
|
||||
chatnet_find(sserver->chatnet);
|
||||
if (chatnet != NULL)
|
||||
server_setup_fill_chatnet(conn, chatnet);
|
||||
|
||||
@ -204,6 +207,7 @@ create_addr_conn(const char *address, int port,
|
||||
conn->nick = g_strdup(nick);
|
||||
}
|
||||
|
||||
signal_emit("server setup fill connect", 1, conn);
|
||||
return conn;
|
||||
}
|
||||
|
||||
@ -239,26 +243,27 @@ create_chatnet_conn(const char *dest, int port,
|
||||
}
|
||||
|
||||
return bestrec == NULL ? NULL :
|
||||
create_addr_conn(bestrec->address, 0, NULL, nick);
|
||||
create_addr_conn(bestrec->chat_type,
|
||||
bestrec->address, 0, NULL, nick);
|
||||
}
|
||||
|
||||
/* Create server connection record. `dest' is required, rest can be NULL.
|
||||
`dest' is either a server address or chat network */
|
||||
SERVER_CONNECT_REC *
|
||||
server_create_conn(const char *dest, int port,
|
||||
server_create_conn(int chat_type, const char *dest, int port,
|
||||
const char *password, const char *nick)
|
||||
{
|
||||
SERVER_CONNECT_REC *rec;
|
||||
|
||||
g_return_val_if_fail(dest != NULL, NULL);
|
||||
|
||||
if (chatnet_find(dest)) {
|
||||
if (chatnet_find(dest) != NULL) {
|
||||
rec = create_chatnet_conn(dest, port, password, nick);
|
||||
if (rec != NULL)
|
||||
return rec;
|
||||
}
|
||||
|
||||
return create_addr_conn(dest, port, password, nick);
|
||||
return create_addr_conn(chat_type, dest, port, password, nick);
|
||||
}
|
||||
|
||||
/* Find matching server from setup. Try to find record with a same port,
|
||||
@ -296,6 +301,7 @@ SERVER_SETUP_REC *server_setup_find_port(const char *address, int port)
|
||||
static SERVER_SETUP_REC *server_setup_read(CONFIG_NODE *node)
|
||||
{
|
||||
SERVER_SETUP_REC *rec;
|
||||
CHATNET_REC *chatnetrec;
|
||||
char *server, *chatnet;
|
||||
int port;
|
||||
|
||||
@ -322,21 +328,28 @@ static SERVER_SETUP_REC *server_setup_read(CONFIG_NODE *node)
|
||||
chatnet = config_node_get_str(node, "chatnet", NULL);
|
||||
}
|
||||
}
|
||||
signal_emit("server setup read", 3, &rec, node,
|
||||
chatnet == NULL ? NULL : chatnet_find(chatnet));
|
||||
if (rec == NULL) {
|
||||
/* no chat protocol wanted this server? */
|
||||
return NULL;
|
||||
|
||||
chatnetrec = chatnet == NULL ? NULL : chatnet_find(chatnet);
|
||||
if (chatnetrec == NULL && chatnet != NULL) {
|
||||
/* chat network not found, create it. */
|
||||
chatnetrec = chat_protocol_get_default()->create_chatnet();
|
||||
chatnetrec->chat_type = chat_protocol_get_default()->id;
|
||||
chatnetrec->name = g_strdup(chatnet);
|
||||
chatnet_create(chatnetrec);
|
||||
}
|
||||
|
||||
rec = CHAT_PROTOCOL(chatnetrec)->create_server_setup();
|
||||
rec->type = module_get_uniq_id("SERVER SETUP", 0);
|
||||
rec->chatnet = g_strdup(chatnet);
|
||||
rec->chat_type = chatnetrec->chat_type;
|
||||
rec->chatnet = g_strdup(chatnetrec->name);
|
||||
rec->address = g_strdup(server);
|
||||
rec->password = g_strdup(config_node_get_str(node, "password", NULL));
|
||||
rec->port = port;
|
||||
rec->autoconnect = config_node_get_bool(node, "autoconnect", FALSE);
|
||||
rec->own_host = g_strdup(config_node_get_str(node, "own_host", NULL));
|
||||
|
||||
signal_emit("server setup read", 2, rec, node);
|
||||
|
||||
setupservers = g_slist_append(setupservers, rec);
|
||||
return rec;
|
||||
}
|
||||
@ -387,8 +400,8 @@ static void server_setup_destroy(SERVER_SETUP_REC *rec)
|
||||
g_free_not_null(rec->own_host);
|
||||
g_free_not_null(rec->own_ip);
|
||||
g_free_not_null(rec->chatnet);
|
||||
g_free(rec->address);
|
||||
g_free_not_null(rec->password);
|
||||
g_free(rec->address);
|
||||
g_free(rec);
|
||||
}
|
||||
|
||||
@ -443,6 +456,7 @@ void servers_setup_init(void)
|
||||
settings_add_int("proxy", "proxy_port", 6667);
|
||||
settings_add_str("proxy", "proxy_string", "CONNECT %s %d");
|
||||
|
||||
setupservers = NULL;
|
||||
source_host_ip = NULL;
|
||||
read_settings();
|
||||
|
||||
|
@ -27,7 +27,7 @@ void server_setup_fill_reconn(SERVER_CONNECT_REC *conn,
|
||||
/* Create server connection record. `dest' is required, rest can be NULL.
|
||||
`dest' is either a server address or chat network */
|
||||
SERVER_CONNECT_REC *
|
||||
server_create_conn(const char *dest, int port,
|
||||
server_create_conn(int chat_type, const char *dest, int port,
|
||||
const char *password, const char *nick);
|
||||
|
||||
/* Find matching server from setup. Try to find record with a same port,
|
||||
|
@ -281,13 +281,9 @@ int server_start_connect(SERVER_REC *server)
|
||||
/* Connect to server */
|
||||
SERVER_REC *server_connect(SERVER_CONNECT_REC *conn)
|
||||
{
|
||||
SERVER_REC *server;
|
||||
|
||||
g_return_val_if_fail(IS_SERVER_CONNECT(conn), NULL);
|
||||
|
||||
server = NULL;
|
||||
signal_emit("server connect", 2, &server, conn);
|
||||
return server;
|
||||
return CHAT_PROTOCOL(conn)->server_connect(conn);
|
||||
}
|
||||
|
||||
static int server_remove_channels(SERVER_REC *server)
|
||||
|
@ -27,6 +27,8 @@
|
||||
#include "misc.h"
|
||||
#include "settings.h"
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "channels.h"
|
||||
#include "channels-setup.h"
|
||||
#include "nicklist.h"
|
||||
@ -232,6 +234,7 @@ static void cmd_channel(const char *data, SERVER_REC *server, WI_ITEM_REC *item)
|
||||
static void cmd_channel_add(const char *data)
|
||||
{
|
||||
GHashTable *optlist;
|
||||
CHATNET_REC *chatnetrec;
|
||||
CHANNEL_SETUP_REC *rec;
|
||||
char *botarg, *botcmdarg, *chatnet, *channel, *password;
|
||||
void *free_arg;
|
||||
@ -240,14 +243,23 @@ static void cmd_channel_add(const char *data)
|
||||
"channel add", &optlist, &channel, &chatnet, &password))
|
||||
return;
|
||||
|
||||
if (*chatnet == '\0' || *channel == '\0')
|
||||
cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
|
||||
|
||||
chatnetrec = chatnet_find(chatnet);
|
||||
if (chatnetrec == NULL) {
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE,
|
||||
TXT_UNKNOWN_CHATNET, chatnet);
|
||||
cmd_params_free(free_arg);
|
||||
return;
|
||||
}
|
||||
|
||||
botarg = g_hash_table_lookup(optlist, "bots");
|
||||
botcmdarg = g_hash_table_lookup(optlist, "botcmd");
|
||||
|
||||
if (*chatnet == '\0' || *channel == '\0')
|
||||
cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
|
||||
rec = channels_setup_find(channel, chatnet);
|
||||
rec = channel_setup_find(channel, chatnet);
|
||||
if (rec == NULL) {
|
||||
rec = g_new0(CHANNEL_SETUP_REC, 1);
|
||||
rec = CHAT_PROTOCOL(chatnetrec)->create_channel_setup();
|
||||
rec->name = g_strdup(channel);
|
||||
rec->chatnet = g_strdup(chatnet);
|
||||
} else {
|
||||
@ -260,8 +272,12 @@ static void cmd_channel_add(const char *data)
|
||||
if (botarg != NULL && *botarg != '\0') rec->botmasks = g_strdup(botarg);
|
||||
if (botcmdarg != NULL && *botcmdarg != '\0') rec->autosendcmd = g_strdup(botcmdarg);
|
||||
if (*password != '\0' && strcmp(password, "-") != 0) rec->password = g_strdup(password);
|
||||
channels_setup_create(rec);
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, TXT_CHANSETUP_ADDED, channel, chatnet);
|
||||
|
||||
signal_emit("channel add fill", 2, rec, optlist);
|
||||
|
||||
channel_setup_create(rec);
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE,
|
||||
TXT_CHANSETUP_ADDED, channel, chatnet);
|
||||
|
||||
cmd_params_free(free_arg);
|
||||
}
|
||||
@ -278,12 +294,12 @@ static void cmd_channel_remove(const char *data)
|
||||
if (*chatnet == '\0' || *channel == '\0')
|
||||
cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
|
||||
|
||||
rec = channels_setup_find(channel, chatnet);
|
||||
rec = channel_setup_find(channel, chatnet);
|
||||
if (rec == NULL)
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, TXT_CHANSETUP_NOT_FOUND, channel, chatnet);
|
||||
else {
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, TXT_CHANSETUP_REMOVED, channel, chatnet);
|
||||
channels_setup_destroy(rec);
|
||||
channel_setup_remove(rec);
|
||||
}
|
||||
cmd_params_free(free_arg);
|
||||
}
|
||||
@ -317,6 +333,10 @@ static void display_sorted_nicks(CHANNEL_REC *channel, GSList *nicklist)
|
||||
g_free(stripped);
|
||||
g_free(format);
|
||||
|
||||
if (settings_get_int("names_max_width") > 0 &&
|
||||
max_width > settings_get_int("names_max_width"))
|
||||
max_width = settings_get_int("names_max_width");
|
||||
|
||||
/* remove width of timestamp from max_width */
|
||||
format_create_dest(&dest, channel->server, channel->name,
|
||||
MSGLEVEL_CLIENTCRAP, NULL);
|
||||
@ -329,10 +349,6 @@ static void display_sorted_nicks(CHANNEL_REC *channel, GSList *nicklist)
|
||||
}
|
||||
|
||||
/* calculate columns */
|
||||
if (settings_get_int("names_max_width") > 0 &&
|
||||
max_width > settings_get_int("names_max_width"))
|
||||
max_width = settings_get_int("names_max_width");
|
||||
|
||||
cols = get_max_column_count(nicklist, get_nick_length, max_width,
|
||||
settings_get_int("names_max_columns"),
|
||||
item_extra, 3, &columns, &rows);
|
||||
|
@ -212,9 +212,13 @@ void glog_func(const char *log_domain, GLogLevelFlags log_level,
|
||||
break;
|
||||
}
|
||||
|
||||
if (windows == NULL)
|
||||
fprintf(stderr, "GLib %s: %s", reason, message);
|
||||
else {
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTERROR,
|
||||
TXT_GLIB_ERROR, reason, message);
|
||||
}
|
||||
}
|
||||
|
||||
void fe_common_core_finish_init(void)
|
||||
{
|
||||
|
@ -48,7 +48,7 @@ static THEME_REC *log_theme;
|
||||
static int skip_next_printtext;
|
||||
static const char *log_theme_name;
|
||||
|
||||
static void log_add_targets(LOG_REC *log, const char *targets)
|
||||
static void log_add_targets(LOG_REC *log, const char *targets, const char *tag)
|
||||
{
|
||||
char **tmp, **items;
|
||||
|
||||
@ -58,15 +58,16 @@ static void log_add_targets(LOG_REC *log, const char *targets)
|
||||
items = g_strsplit(targets, " ", -1);
|
||||
|
||||
for (tmp = items; *tmp != NULL; tmp++)
|
||||
log_item_add(log, LOG_ITEM_TARGET, *tmp, NULL);
|
||||
log_item_add(log, LOG_ITEM_TARGET, *tmp, tag);
|
||||
|
||||
g_strfreev(items);
|
||||
}
|
||||
|
||||
/* SYNTAX: LOG OPEN [-noopen] [-autoopen] [-targets <targets>]
|
||||
[-window] <fname> [<levels>] */
|
||||
/* SYNTAX: LOG OPEN [-noopen] [-autoopen] [-window] [-<server tag>]
|
||||
[-targets <targets>] <fname> [<levels>] */
|
||||
static void cmd_log_open(const char *data)
|
||||
{
|
||||
SERVER_REC *server;
|
||||
GHashTable *optlist;
|
||||
char *targetarg, *fname, *levels;
|
||||
void *free_arg;
|
||||
@ -74,7 +75,8 @@ static void cmd_log_open(const char *data)
|
||||
LOG_REC *log;
|
||||
int level;
|
||||
|
||||
if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_OPTIONS | PARAM_FLAG_GETREST,
|
||||
if (!cmd_get_params(data, &free_arg, 2 | PARAM_FLAG_GETREST |
|
||||
PARAM_FLAG_UNKNOWN_OPTIONS | PARAM_FLAG_OPTIONS,
|
||||
"log open", &optlist, &fname, &levels))
|
||||
return;
|
||||
if (*fname == '\0') cmd_param_error(CMDERR_NOT_ENOUGH_PARAMS);
|
||||
@ -82,14 +84,17 @@ static void cmd_log_open(const char *data)
|
||||
level = level2bits(levels);
|
||||
log = log_create_rec(fname, level != 0 ? level : MSGLEVEL_ALL);
|
||||
|
||||
/* -<server tag> */
|
||||
server = cmd_options_get_server("join", optlist, NULL);
|
||||
|
||||
if (g_hash_table_lookup(optlist, "window")) {
|
||||
/* log by window ref# */
|
||||
ltoa(window, active_win->refnum);
|
||||
log_item_add(log, LOG_ITEM_WINDOW_REFNUM, window, NULL);
|
||||
log_item_add(log, LOG_ITEM_WINDOW_REFNUM, window, server->tag);
|
||||
} else {
|
||||
targetarg = g_hash_table_lookup(optlist, "targets");
|
||||
if (targetarg != NULL && *targetarg != '\0')
|
||||
log_add_targets(log, targetarg);
|
||||
log_add_targets(log, targetarg, server->tag);
|
||||
}
|
||||
|
||||
if (g_hash_table_lookup(optlist, "autoopen"))
|
||||
@ -217,7 +222,7 @@ static void cmd_log(const char *data, SERVER_REC *server, void *item)
|
||||
}
|
||||
|
||||
static LOG_REC *logs_find_item(int type, const char *item,
|
||||
SERVER_REC *server, LOG_ITEM_REC **ret_item)
|
||||
const char *servertag, LOG_ITEM_REC **ret_item)
|
||||
{
|
||||
LOG_ITEM_REC *logitem;
|
||||
GSList *tmp;
|
||||
@ -225,7 +230,7 @@ static LOG_REC *logs_find_item(int type, const char *item,
|
||||
for (tmp = logs; tmp != NULL; tmp = tmp->next) {
|
||||
LOG_REC *log = tmp->data;
|
||||
|
||||
logitem = log_item_find(log, type, item, server);
|
||||
logitem = log_item_find(log, type, item, servertag);
|
||||
if (logitem != NULL) {
|
||||
if (ret_item != NULL) *ret_item = logitem;
|
||||
return log;
|
||||
@ -338,12 +343,13 @@ static void autologs_close_all(void)
|
||||
}
|
||||
}
|
||||
|
||||
static void autolog_open(void *server, const char *target)
|
||||
static void autolog_open(SERVER_REC *server, const char *target)
|
||||
{
|
||||
LOG_REC *log;
|
||||
char *fname, *dir, *fixed_target;
|
||||
char *fname, *dir, *fixed_target, *tag;
|
||||
|
||||
log = logs_find_item(LOG_ITEM_TARGET, target, server, NULL);
|
||||
tag = server == NULL ? NULL : server->tag;
|
||||
log = logs_find_item(LOG_ITEM_TARGET, target, tag, NULL);
|
||||
if (log != NULL && !log->failed) {
|
||||
log_start_logging(log);
|
||||
return;
|
||||
@ -359,7 +365,7 @@ static void autolog_open(void *server, const char *target)
|
||||
|
||||
if (log_find(fname) == NULL) {
|
||||
log = log_create_rec(fname, autolog_level);
|
||||
log_item_add(log, LOG_ITEM_TARGET, target, server);
|
||||
log_item_add(log, LOG_ITEM_TARGET, target, tag);
|
||||
|
||||
dir = g_dirname(log->real_fname);
|
||||
mkpath(dir, LOG_DIR_CREATE_MODE);
|
||||
@ -372,7 +378,8 @@ static void autolog_open(void *server, const char *target)
|
||||
g_free(fname);
|
||||
}
|
||||
|
||||
static void autolog_open_check(void *server, const char *target, int level)
|
||||
static void autolog_open_check(SERVER_REC *server, const char *target,
|
||||
int level)
|
||||
{
|
||||
char **targets, **tmp;
|
||||
|
||||
@ -410,7 +417,7 @@ static void log_single_line(WINDOW_REC *window, void *server,
|
||||
}
|
||||
}
|
||||
|
||||
static void log_line(WINDOW_REC *window, void *server,
|
||||
static void log_line(WINDOW_REC *window, SERVER_REC *server,
|
||||
const char *target, int level, const char *text)
|
||||
{
|
||||
char **lines, **tmp;
|
||||
@ -513,7 +520,9 @@ static void sig_window_item_destroy(WINDOW_REC *window, WI_ITEM_REC *item)
|
||||
{
|
||||
LOG_REC *log;
|
||||
|
||||
log = logs_find_item(LOG_ITEM_TARGET, item->name, item->server, NULL);
|
||||
log = logs_find_item(LOG_ITEM_TARGET, item->name,
|
||||
item->server == NULL ? NULL :
|
||||
item->server->tag, NULL);
|
||||
if (log != NULL && log->temp)
|
||||
log_close(log);
|
||||
}
|
||||
|
@ -23,9 +23,10 @@
|
||||
#include "modules.h"
|
||||
#include "signals.h"
|
||||
#include "commands.h"
|
||||
#include "levels.h"
|
||||
#include "settings.h"
|
||||
|
||||
#include "levels.h"
|
||||
#include "chat-protocols.h"
|
||||
#include "queries.h"
|
||||
|
||||
#include "fe-windows.h"
|
||||
@ -46,8 +47,8 @@ QUERY_REC *privmsg_get_query(SERVER_REC *server, const char *nick,
|
||||
query = query_find(server, nick);
|
||||
if (query == NULL && (querycreate_level & level) != 0 &&
|
||||
(!own || settings_get_bool("autocreate_own_query"))) {
|
||||
query = query_create(server->chat_type, server->tag,
|
||||
nick, TRUE);
|
||||
query = CHAT_PROTOCOL(server)->
|
||||
query_create(server->tag, nick, TRUE);
|
||||
}
|
||||
|
||||
return query;
|
||||
@ -228,7 +229,7 @@ static void cmd_query(const char *data, SERVER_REC *server, WI_ITEM_REC *item)
|
||||
|
||||
query = query_find(server, nick);
|
||||
if (query == NULL)
|
||||
query_create(server->chat_type, server->tag, nick, FALSE);
|
||||
CHAT_PROTOCOL(server)->query_create(server->tag, nick, FALSE);
|
||||
else {
|
||||
/* query already existed - set query active / move it to this
|
||||
window */
|
||||
|
@ -1,7 +1,7 @@
|
||||
/*
|
||||
fe-server.c : irssi
|
||||
|
||||
Copyright (C) 1999 Timo Sirainen
|
||||
Copyright (C) 1999-2001 Timo Sirainen
|
||||
|
||||
This program is free software; you can redistribute it and/or modify
|
||||
it under the terms of the GNU General Public License as published by
|
||||
@ -26,6 +26,7 @@
|
||||
#include "settings.h"
|
||||
|
||||
#include "chat-protocols.h"
|
||||
#include "chatnets.h"
|
||||
#include "servers.h"
|
||||
#include "servers-setup.h"
|
||||
#include "servers-reconnect.h"
|
||||
@ -80,9 +81,29 @@ static void print_reconnects(void)
|
||||
}
|
||||
}
|
||||
|
||||
/* SYNTAX: SERVER ADD [-auto | -noauto] [-host <hostname>]
|
||||
[-cmdspeed <ms>] [-cmdmax <count>] [-port <port>]
|
||||
<address> [<port> [<password>]] */
|
||||
static SERVER_SETUP_REC *create_server_setup(GHashTable *optlist)
|
||||
{
|
||||
CHAT_PROTOCOL_REC *rec;
|
||||
SERVER_SETUP_REC *server;
|
||||
char *chatnet;
|
||||
|
||||
rec = chat_protocol_find_net(optlist);
|
||||
if (rec == NULL)
|
||||
rec = chat_protocol_get_default();
|
||||
else {
|
||||
chatnet = g_hash_table_lookup(optlist, rec->chatnet);
|
||||
if (chatnet_find(chatnet) == NULL) {
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE,
|
||||
TXT_UNKNOWN_CHATNET, chatnet);
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
server = rec->create_server_setup();
|
||||
server->chat_type = rec->id;
|
||||
return server;
|
||||
}
|
||||
|
||||
static void cmd_server_add(const char *data)
|
||||
{
|
||||
GHashTable *optlist;
|
||||
@ -100,17 +121,11 @@ static void cmd_server_add(const char *data)
|
||||
|
||||
rec = server_setup_find_port(addr, port);
|
||||
if (rec == NULL) {
|
||||
signal_emit("server add create", 2, &rec, optlist);
|
||||
rec = create_server_setup(optlist);
|
||||
if (rec == NULL) {
|
||||
/* no chatnet option specified, use the first. */
|
||||
g_hash_table_insert(optlist, chat_protocol_find_id(1)->name, "");
|
||||
signal_emit("server add create", 2, &rec, optlist);
|
||||
if (rec == NULL) {
|
||||
/* bug? */
|
||||
cmd_params_free(free_arg);
|
||||
return;
|
||||
}
|
||||
}
|
||||
rec->address = g_strdup(addr);
|
||||
rec->port = port;
|
||||
} else {
|
||||
@ -137,7 +152,8 @@ static void cmd_server_add(const char *data)
|
||||
signal_emit("server add fill", 2, rec, optlist);
|
||||
|
||||
server_setup_add(rec);
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE, TXT_SETUPSERVER_ADDED, addr, port);
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTNOTICE,
|
||||
TXT_SETUPSERVER_ADDED, addr, port);
|
||||
|
||||
cmd_params_free(free_arg);
|
||||
}
|
||||
|
@ -207,6 +207,7 @@ FORMAT_REC fecommon_core_formats[] = {
|
||||
/* ---- */
|
||||
{ NULL, "Misc", 0 },
|
||||
|
||||
{ "unknown_chatnet", "Unknown chat network: $0", 1, { 0 } },
|
||||
{ "not_toggle", "Value must be either ON, OFF or TOGGLE", 0 },
|
||||
{ "perl_error", "Perl error: $0", 1, { 0 } },
|
||||
{ "bind_key", "$[10]0 $1 $2", 3, { 0, 0, 0 } },
|
||||
|
@ -173,6 +173,7 @@ enum {
|
||||
|
||||
TXT_FILL_13,
|
||||
|
||||
TXT_UNKNOWN_CHATNET,
|
||||
TXT_NOT_TOGGLE,
|
||||
TXT_PERL_ERROR,
|
||||
TXT_BIND_KEY,
|
||||
|
@ -53,8 +53,7 @@ static void sig_window_restore_item(WINDOW_REC *window, const char *type,
|
||||
rec->sticky = TRUE;
|
||||
} else if (g_strcasecmp(type, "QUERY") == 0 && chat_type != NULL) {
|
||||
/* create query immediately */
|
||||
query_create(chat_protocol_lookup(chat_type),
|
||||
tag, name, TRUE);
|
||||
chat_protocol_find(chat_type)->query_create(tag, name, TRUE);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -34,20 +34,9 @@
|
||||
#include "fe-windows.h"
|
||||
#include "printtext.h"
|
||||
|
||||
static void sig_server_add_create(IRC_SERVER_SETUP_REC **rec,
|
||||
GHashTable *optlist)
|
||||
{
|
||||
char *ircnet;
|
||||
|
||||
ircnet = g_hash_table_lookup(optlist, "ircnet");
|
||||
if (ircnet == NULL)
|
||||
return;
|
||||
|
||||
*rec = g_new0(IRC_SERVER_SETUP_REC, 1);
|
||||
(*rec)->chat_type = chat_protocol_lookup("IRC");
|
||||
signal_stop();
|
||||
}
|
||||
|
||||
/* SYNTAX: SERVER ADD [-auto | -noauto] [-ircnet <ircnet>] [-host <hostname>]
|
||||
[-cmdspeed <ms>] [-cmdmax <count>] [-port <port>]
|
||||
<address> [<port> [<password>]] */
|
||||
static void sig_server_add_fill(IRC_SERVER_SETUP_REC *rec,
|
||||
GHashTable *optlist)
|
||||
{
|
||||
@ -107,7 +96,6 @@ static void cmd_server_list(const char *data)
|
||||
|
||||
void fe_irc_server_init(void)
|
||||
{
|
||||
signal_add("server add create", (SIGNAL_FUNC) sig_server_add_create);
|
||||
signal_add("server add fill", (SIGNAL_FUNC) sig_server_add_fill);
|
||||
command_bind("server list", NULL, (SIGNAL_FUNC) cmd_server_list);
|
||||
|
||||
@ -116,7 +104,6 @@ void fe_irc_server_init(void)
|
||||
|
||||
void fe_irc_server_deinit(void)
|
||||
{
|
||||
signal_remove("server add create", (SIGNAL_FUNC) sig_server_add_create);
|
||||
signal_remove("server add fill", (SIGNAL_FUNC) sig_server_add_fill);
|
||||
command_unbind("server list", (SIGNAL_FUNC) cmd_server_list);
|
||||
}
|
||||
|
@ -79,11 +79,11 @@ static void cmd_ircnet_list(void)
|
||||
printformat(NULL, NULL, MSGLEVEL_CLIENTCRAP, IRCTXT_IRCNET_FOOTER);
|
||||
}
|
||||
|
||||
/* SYNTAX: IRCNET ADD [-kicks <count>] [-msgs <count>] [-modes <count>]
|
||||
[-whois <count>] [-cmdspeed <ms>] [-cmdmax <count>]
|
||||
[-querychans <count>] [-nick <nick>] [-user <user>]
|
||||
[-realname <name>] [-host <host>] [-autosendcmd <cmd>]
|
||||
<name> */
|
||||
/* SYNTAX: IRCNET ADD [-nick <nick>] [-user <user>] [-realname <name>]
|
||||
[-host <host>] [-autosendcmd <cmd>]
|
||||
[-querychans <count>] [-whois <count>] [-msgs <count>]
|
||||
[-kicks <count>] [-modes <count>]
|
||||
[-cmdspeed <ms>] [-cmdmax <count>] <name> */
|
||||
static void cmd_ircnet_add(const char *data)
|
||||
{
|
||||
GHashTable *optlist;
|
||||
@ -176,6 +176,7 @@ static void cmd_ircnet(const char *data, IRC_SERVER_REC *server, WI_ITEM_REC *it
|
||||
void fe_ircnet_init(void)
|
||||
{
|
||||
command_bind("ircnet", NULL, (SIGNAL_FUNC) cmd_ircnet);
|
||||
command_bind("ircnet list", NULL, (SIGNAL_FUNC) cmd_ircnet_list);
|
||||
command_bind("ircnet add", NULL, (SIGNAL_FUNC) cmd_ircnet_add);
|
||||
command_bind("ircnet remove", NULL, (SIGNAL_FUNC) cmd_ircnet_remove);
|
||||
|
||||
@ -185,6 +186,7 @@ void fe_ircnet_init(void)
|
||||
void fe_ircnet_deinit(void)
|
||||
{
|
||||
command_unbind("ircnet", (SIGNAL_FUNC) cmd_ircnet);
|
||||
command_unbind("ircnet list", (SIGNAL_FUNC) cmd_ircnet_list);
|
||||
command_unbind("ircnet add", (SIGNAL_FUNC) cmd_ircnet_add);
|
||||
command_unbind("ircnet remove", (SIGNAL_FUNC) cmd_ircnet_remove);
|
||||
}
|
||||
|
@ -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);
|
||||
|
||||
|
@ -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;
|
||||
g_return_if_fail(rec != NULL);
|
||||
|
||||
if (node == NULL || node->key == NULL)
|
||||
return;
|
||||
|
||||
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);
|
||||
}
|
||||
|
@ -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)
|
||||
|
@ -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();
|
||||
|
@ -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);
|
||||
}
|
||||
|
@ -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);
|
||||
|
@ -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);
|
||||
|
Loading…
Reference in New Issue
Block a user