summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2006-08-28 12:09:09 +0000
committerSebastien Helleu <flashcode@flashtux.org>2006-08-28 12:09:09 +0000
commit3eb2b1dc0f8b4f1c6517da1802548a8d8e39c9ee (patch)
tree35ff331f166525356b4215405d86cbf02b68a1ad /src
parent11acdddda3c92ff3de5c322a5872c087cd217825 (diff)
downloadweechat-3eb2b1dc0f8b4f1c6517da1802548a8d8e39c9ee.zip
Fixed bug with CTCP VERSION sent on channels (bug #17547), added current channel completion for /ctcp command
Diffstat (limited to 'src')
-rw-r--r--src/irc/irc-commands.c6
-rw-r--r--src/irc/irc-recv.c125
2 files changed, 76 insertions, 55 deletions
diff --git a/src/irc/irc-commands.c b/src/irc/irc-commands.c
index dd6befc40..a083e07dd 100644
--- a/src/irc/irc-commands.c
+++ b/src/irc/irc-commands.c
@@ -54,11 +54,11 @@ t_irc_command irc_commands[] =
"nickname: user or host to ban"),
"%N", 0, MAX_ARGS, 0, 1, NULL, irc_cmd_send_ban, NULL },
{ "ctcp", N_("send a CTCP message (Client-To-Client Protocol)"),
- N_("nickname type [arguments]"),
- N_(" nickname: user to send CTCP to\n"
+ N_("receiver type [arguments]"),
+ N_(" receiver: nick or channel to send CTCP to\n"
" type: CTCP type (examples: \"version\", \"ping\", ..)\n"
"arguments: arguments for CTCP"),
- "%n action|ping|version", 2, MAX_ARGS, 1, 1, NULL, irc_cmd_send_ctcp, NULL },
+ "%c|%n action|ping|version", 2, MAX_ARGS, 1, 1, NULL, irc_cmd_send_ctcp, NULL },
{ "cycle", N_("leave and rejoin a channel"),
N_("[channel[,channel]] [part_message]"),
N_(" channel: channel name for cycle\n"
diff --git a/src/irc/irc-recv.c b/src/irc/irc-recv.c
index 7de6aa4e8..3ef4a2148 100644
--- a/src/irc/irc-recv.c
+++ b/src/irc/irc-recv.c
@@ -1211,6 +1211,73 @@ irc_cmd_recv_pong (t_irc_server *server, char *host, char *nick, char *arguments
}
/*
+ * irc_cmd_reply_version: send version in reply to "CTCP VERSION" request
+ */
+
+void
+irc_cmd_reply_version (t_irc_server *server, t_irc_channel *channel,
+ char *host, char *nick, char *message)
+{
+ char *pos;
+ struct utsname *buf;
+ t_gui_buffer *ptr_buffer;
+
+ ptr_buffer = (channel) ? channel->buffer : server->buffer;
+
+ command_ignored |= ignore_check (host, "ctcp", NULL, server->name);
+ if (!command_ignored)
+ {
+ pos = strchr (message, ' ');
+ if (pos)
+ {
+ while (pos[0] == ' ')
+ pos++;
+ if (pos[0] == '\01')
+ pos = NULL;
+ else if (!pos[0])
+ pos = NULL;
+ }
+
+ buf = (struct utsname *) malloc (sizeof (struct utsname));
+ if (buf && (uname (buf) >= 0))
+ {
+ server_sendf (server,
+ "NOTICE %s :%sVERSION %s v%s"
+ " compiled on %s, running "
+ "%s %s / %s%s",
+ nick, "\01", PACKAGE_NAME, PACKAGE_VERSION, __DATE__,
+ &buf->sysname,
+ &buf->release, &buf->machine, "\01\r\n");
+ free (buf);
+ }
+ else
+ server_sendf (server,
+ "NOTICE %s :%sVERSION %s v%s"
+ " compiled on %s%s",
+ nick, "\01", PACKAGE_NAME, PACKAGE_VERSION, __DATE__,
+ "\01\r\n");
+ irc_display_prefix (server, ptr_buffer, PREFIX_SERVER);
+ gui_printf (ptr_buffer,
+ _("CTCP %sVERSION%s received from %s%s"),
+ GUI_COLOR(COLOR_WIN_CHAT_CHANNEL),
+ GUI_COLOR(COLOR_WIN_CHAT),
+ GUI_COLOR(COLOR_WIN_CHAT_NICK),
+ nick);
+ if (pos)
+ gui_printf (ptr_buffer, "%s: %s\n",
+ GUI_COLOR(COLOR_WIN_CHAT),
+ pos);
+ else
+ gui_printf (ptr_buffer, "\n");
+#ifdef PLUGINS
+ (void) plugin_msg_handler_exec (server->name,
+ "weechat_ctcp",
+ irc_last_command_received);
+#endif
+ }
+}
+
+/*
* irc_cmd_recv_privmsg: 'privmsg' command received
*/
@@ -1221,7 +1288,6 @@ irc_cmd_recv_privmsg (t_irc_server *server, char *host, char *nick, char *argume
char *pos_file, *pos_addr, *pos_port, *pos_size, *pos_start_resume; /* for DCC */
t_irc_channel *ptr_channel;
t_irc_nick *ptr_nick;
- struct utsname *buf;
int highlight;
/* no host => we can't identify sender of message! */
@@ -1350,6 +1416,11 @@ irc_cmd_recv_privmsg (t_irc_server *server, char *host, char *nick, char *argume
nick);
return 0;
}
+ if (strncmp (pos, "\01VERSION", 8) == 0)
+ {
+ irc_cmd_reply_version (server, ptr_channel, host, nick, pos);
+ return 0;
+ }
/* unknown CTCP ? */
pos2 = strchr (pos + 1, '\01');
@@ -1451,57 +1522,7 @@ irc_cmd_recv_privmsg (t_irc_server *server, char *host, char *nick, char *argume
/* version asked by another user => answer with WeeChat version */
if (strncmp (pos, "\01VERSION", 8) == 0)
{
- command_ignored |= ignore_check (host, "ctcp", NULL, server->name);
- if (!command_ignored)
- {
- pos2 = strchr (pos + 8, ' ');
- if (pos2)
- {
- while (pos2[0] == ' ')
- pos2++;
- if (pos2[0] == '\01')
- pos2 = NULL;
- else if (!pos2[0])
- pos2 = NULL;
- }
-
- buf = (struct utsname *) malloc (sizeof (struct utsname));
- if (buf && (uname (buf) >= 0))
- {
- server_sendf (server,
- "NOTICE %s :%sVERSION %s v%s"
- " compiled on %s, running "
- "%s %s / %s%s",
- nick, "\01", PACKAGE_NAME, PACKAGE_VERSION, __DATE__,
- &buf->sysname,
- &buf->release, &buf->machine, "\01\r\n");
- free (buf);
- }
- else
- server_sendf (server,
- "NOTICE %s :%sVERSION %s v%s"
- " compiled on %s%s",
- nick, "\01", PACKAGE_NAME, PACKAGE_VERSION, __DATE__,
- "\01\r\n");
- irc_display_prefix (server, server->buffer, PREFIX_SERVER);
- gui_printf (server->buffer,
- _("CTCP %sVERSION%s received from %s%s"),
- GUI_COLOR(COLOR_WIN_CHAT_CHANNEL),
- GUI_COLOR(COLOR_WIN_CHAT),
- GUI_COLOR(COLOR_WIN_CHAT_NICK),
- nick);
- if (pos2)
- gui_printf (server->buffer, "%s: %s\n",
- GUI_COLOR(COLOR_WIN_CHAT),
- pos2);
- else
- gui_printf (server->buffer, "\n");
-#ifdef PLUGINS
- (void) plugin_msg_handler_exec (server->name,
- "weechat_ctcp",
- irc_last_command_received);
-#endif
- }
+ irc_cmd_reply_version (server, NULL, host, nick, pos);
return 0;
}