aboutsummaryrefslogtreecommitdiffstats
path: root/ipc.c
diff options
context:
space:
mode:
authorWilmer van der Gaast <wilmer@gaast.net>2010-07-09 22:06:38 +0100
committerWilmer van der Gaast <wilmer@gaast.net>2010-07-09 22:06:38 +0100
commitdebe871bbd96a1d4215983265d97b8f0df7a4fbf (patch)
tree25d2d02d49319ead7c0c296a65f2413c3c72d1f5 /ipc.c
parent9595d2b9420afc1044c0d5ee93311b8c4ee6dec2 (diff)
Inform IPC master about nick changes.
Diffstat (limited to 'ipc.c')
-rw-r--r--ipc.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/ipc.c b/ipc.c
index aad05bbf..3c98c41e 100644
--- a/ipc.c
+++ b/ipc.c
@@ -49,11 +49,23 @@ static void ipc_master_cmd_client( irc_t *data, char **cmd )
child->realname = g_strdup( cmd[3] );
}
+ /* CLIENT == On initial connects, HELLO is after /RESTARTs. */
if( g_strcasecmp( cmd[0], "CLIENT" ) == 0 )
ipc_to_children_str( "OPERMSG :Client connecting (PID=%d): %s@%s (%s)\r\n",
(int) ( child ? child->pid : -1 ), cmd[2], cmd[1], cmd[3] );
}
+static void ipc_master_cmd_nick( irc_t *data, char **cmd )
+{
+ struct bitlbee_child *child = (void*) data;
+
+ if( child && cmd[1] )
+ {
+ g_free( child->nick );
+ child->nick = g_strdup( cmd[1] );
+ }
+}
+
static void ipc_master_cmd_die( irc_t *data, char **cmd )
{
if( global.conf->runmode == RUNMODE_FORKDAEMON )
@@ -207,6 +219,7 @@ void ipc_master_cmd_takeover( irc_t *data, char **cmd )
static const command_t ipc_master_commands[] = {
{ "client", 3, ipc_master_cmd_client, 0 },
{ "hello", 0, ipc_master_cmd_client, 0 },
+ { "nick", 1, ipc_master_cmd_nick, 0 },
{ "die", 0, ipc_master_cmd_die, 0 },
{ "deaf", 0, ipc_master_cmd_deaf, 0 },
{ "wallops", 1, NULL, IPC_CMD_TO_CHILDREN },