summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2008-01-04 23:47:26 +0100
committerSebastien Helleu <flashcode@flashtux.org>2008-01-04 23:47:26 +0100
commit2b7c8eb73b5b8ac45c389ebc86671c2f0c487de0 (patch)
tree503315e92c57382c4959f1f491677674e30049b8 /src
parent23273bf47a94c759d36584dad7053f0867556869 (diff)
downloadweechat-2b7c8eb73b5b8ac45c389ebc86671c2f0c487de0.zip
Fixed data input in channel buffers (IRC plugin)
Diffstat (limited to 'src')
-rw-r--r--src/plugins/irc/Makefile.am2
-rw-r--r--src/plugins/irc/irc-channel.c4
-rw-r--r--src/plugins/irc/irc-input.c122
-rw-r--r--src/plugins/irc/irc-input.h25
4 files changed, 88 insertions, 65 deletions
diff --git a/src/plugins/irc/Makefile.am b/src/plugins/irc/Makefile.am
index bf856a86d..599886020 100644
--- a/src/plugins/irc/Makefile.am
+++ b/src/plugins/irc/Makefile.am
@@ -34,6 +34,7 @@ irc_la_SOURCES = irc.c \
irc-config.h \
irc-display.c \
irc-display.h \
+ irc-input.c \
irc-mode.c \
irc-mode.h \
irc-nick.c \
@@ -47,7 +48,6 @@ irc_la_SOURCES = irc.c \
# irc-buffer.h \
# irc-dcc.c \
# irc-dcc.h \
-# irc-input.c \
# irc-log.c
irc_la_LDFLAGS = -module
diff --git a/src/plugins/irc/irc-channel.c b/src/plugins/irc/irc-channel.c
index fb9a08c5c..81d119d15 100644
--- a/src/plugins/irc/irc-channel.c
+++ b/src/plugins/irc/irc-channel.c
@@ -33,6 +33,7 @@
#include "irc-dcc.h"
#include "irc-nick.h"
#include "irc-server.h"
+#include "irc-input.h"
/*
@@ -57,7 +58,8 @@ irc_channel_new (struct t_irc_server *server, int channel_type,
}
/* create buffer for channel */
- new_buffer = weechat_buffer_new (server->name, channel_name, NULL);
+ new_buffer = weechat_buffer_new (server->name, channel_name,
+ &irc_input_data);
if (!new_buffer)
{
free (new_channel);
diff --git a/src/plugins/irc/irc-input.c b/src/plugins/irc/irc-input.c
index 553b2955e..bf3e40b8e 100644
--- a/src/plugins/irc/irc-input.c
+++ b/src/plugins/irc/irc-input.c
@@ -26,11 +26,13 @@
#include <stdlib.h>
#include <string.h>
-#include "../../core/weechat.h"
#include "irc.h"
-#include "../../core/utf8.h"
-#include "../../core/weechat-config.h"
-#include "../../gui/gui.h"
+#include "irc-server.h"
+#include "irc-channel.h"
+#include "irc-nick.h"
+#include "irc-dcc.h"
+#include "irc-color.h"
+#include "irc-config.h"
/*
@@ -38,45 +40,41 @@
*/
void
-irc_input_user_message_display (t_gui_window *window, char *text)
+irc_input_user_message_display (struct t_gui_buffer *buffer, char *text)
{
- t_irc_nick *ptr_nick;
-
- IRC_BUFFER_GET_SERVER_CHANNEL(window->buffer);
+ struct t_irc_nick *ptr_nick;
- if ((ptr_channel->type == IRC_CHANNEL_TYPE_PRIVATE)
- || (ptr_channel->type == IRC_CHANNEL_TYPE_DCC_CHAT))
- {
- irc_display_nick (window->buffer, NULL, ptr_server->nick,
- GUI_MSG_TYPE_NICK, 1,
- GUI_COLOR(GUI_COLOR_CHAT_NICK_SELF), 0);
- gui_chat_printf_type (window->buffer,
- GUI_MSG_TYPE_MSG,
- NULL, -1,
- "%s%s\n",
- GUI_COLOR(GUI_COLOR_CHAT),
- text);
- }
- else
+ IRC_GET_SERVER_CHANNEL(buffer);
+
+ if (ptr_channel)
{
- ptr_nick = irc_nick_search (ptr_channel, ptr_server->nick);
- if (ptr_nick)
+ if ((ptr_channel->type == IRC_CHANNEL_TYPE_PRIVATE)
+ || (ptr_channel->type == IRC_CHANNEL_TYPE_DCC_CHAT))
{
- irc_display_nick (window->buffer, ptr_nick, NULL,
- GUI_MSG_TYPE_NICK, 1, NULL, 0);
- gui_chat_printf_type (window->buffer,
- GUI_MSG_TYPE_MSG,
- NULL, -1,
- "%s%s\n",
- GUI_COLOR(GUI_COLOR_CHAT),
- text);
+ weechat_printf (buffer,
+ "%s%s",
+ irc_nick_as_prefix (NULL, ptr_server->nick,
+ IRC_COLOR_CHAT_NICK_SELF),
+ text);
}
else
{
- gui_chat_printf_error (ptr_server->buffer,
- _("%s cannot find nick for sending "
- "message\n"),
- WEECHAT_ERROR);
+ ptr_nick = irc_nick_search (ptr_channel, ptr_server->nick);
+ if (ptr_nick)
+ {
+ weechat_printf (buffer,
+ "%s%s",
+ irc_nick_as_prefix (ptr_nick, NULL,
+ IRC_COLOR_CHAT_NICK_SELF),
+ text);
+ }
+ else
+ {
+ weechat_printf (ptr_server->buffer,
+ _("%s%s: cannot find nick for sending "
+ "message"),
+ weechat_prefix ("error"), "irc");
+ }
}
}
}
@@ -87,21 +85,21 @@ irc_input_user_message_display (t_gui_window *window, char *text)
*/
void
-irc_input_send_user_message (t_gui_window *window, char *text)
+irc_input_send_user_message (struct t_gui_buffer *buffer, char *text)
{
int max_length;
char *pos, *pos_next, *pos_max, *next, saved_char, *last_space;
- IRC_BUFFER_GET_SERVER_CHANNEL(window->buffer);
+ IRC_GET_SERVER_CHANNEL(buffer);
if (!ptr_server || !ptr_channel || !text || !text[0])
return;
if (!ptr_server->is_connected)
{
- gui_chat_printf_error (window->buffer,
- _("%s you are not connected to server\n"),
- WEECHAT_ERROR);
+ weechat_printf (buffer,
+ _("%s%s: you are not connected to server"),
+ weechat_prefix ("error"), "irc");
return;
}
@@ -122,7 +120,7 @@ irc_input_send_user_message (t_gui_window *window, char *text)
{
if (pos[0] == ' ')
last_space = pos;
- pos_next = utf8_next_char (pos);
+ pos_next = weechat_utf8_next_char (pos);
if (pos_next > pos_max)
break;
pos = pos_next;
@@ -137,12 +135,12 @@ irc_input_send_user_message (t_gui_window *window, char *text)
irc_server_sendf_queued (ptr_server, "PRIVMSG %s :%s",
ptr_channel->name, text);
- irc_input_user_message_display (window, text);
+ irc_input_user_message_display (buffer, text);
if (next)
{
next[0] = saved_char;
- irc_input_send_user_message (window, next);
+ irc_input_send_user_message (buffer, next);
}
}
@@ -152,38 +150,38 @@ irc_input_send_user_message (t_gui_window *window, char *text)
* PROTOCOL_RC_KO if error
*/
-int
-irc_input_data (t_gui_window *window, char *data)
+void
+irc_input_data (struct t_gui_buffer *buffer, char *data)
{
char *data_with_colors;
- IRC_BUFFER_GET_CHANNEL(window->buffer);
+ IRC_GET_SERVER_CHANNEL(buffer);
if (ptr_channel)
{
data_with_colors = (char *)irc_color_encode ((unsigned char *)data,
- irc_cfg_irc_colors_send);
+ weechat_config_boolean (irc_config_irc_colors_send));
if (ptr_channel->dcc_chat)
{
if (ptr_channel->dcc_chat->sock < 0)
{
- gui_chat_printf_error_nolog (window->buffer,
- "%s DCC CHAT is closed\n",
- WEECHAT_ERROR);
+ weechat_printf (buffer,
+ "%s%s: DCC CHAT is closed",
+ weechat_prefix ("error"), "irc");
}
else
{
- irc_dcc_chat_sendf (ptr_channel->dcc_chat,
- "%s\r\n",
- (data_with_colors) ? data_with_colors : data);
- irc_input_user_message_display (window,
- (data_with_colors) ?
- data_with_colors : data);
+ //irc_dcc_chat_sendf (ptr_channel->dcc_chat,
+ // "%s\r\n",
+ // (data_with_colors) ? data_with_colors : data);
+ //irc_input_user_message_display (buffer,
+ // (data_with_colors) ?
+ // data_with_colors : data);
}
}
else
- irc_input_send_user_message (window,
+ irc_input_send_user_message (buffer,
(data_with_colors) ? data_with_colors : data);
if (data_with_colors)
@@ -191,10 +189,8 @@ irc_input_data (t_gui_window *window, char *data)
}
else
{
- gui_chat_printf_error_nolog (window->buffer,
- _("This buffer is not a channel!\n"));
- return PROTOCOL_RC_KO;
+ weechat_printf (buffer,
+ _("%s: this buffer is not a channel!"),
+ "irc");
}
-
- return PROTOCOL_RC_OK;
}
diff --git a/src/plugins/irc/irc-input.h b/src/plugins/irc/irc-input.h
new file mode 100644
index 000000000..8fefc8da7
--- /dev/null
+++ b/src/plugins/irc/irc-input.h
@@ -0,0 +1,25 @@
+/*
+ * Copyright (c) 2003-2008 by FlashCode <flashcode@flashtux.org>
+ * See README for License detail, AUTHORS for developers list.
+ *
+ * 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
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+
+#ifndef __WEECHAT_IRC_INPUT_H
+#define __WEECHAT_IRC_INPUT_H 1
+
+extern void irc_input_data (struct t_gui_buffer *buffer, char *data);
+
+#endif /* irc-input.h */