summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/plugins/irc/irc-buffer.c2
-rw-r--r--src/plugins/irc/irc-command.c5
-rw-r--r--src/plugins/irc/irc-protocol.c1
-rw-r--r--src/plugins/irc/irc-server.c100
-rw-r--r--src/plugins/irc/irc-server.h4
-rw-r--r--src/plugins/irc/irc-upgrade.c3
6 files changed, 86 insertions, 29 deletions
diff --git a/src/plugins/irc/irc-buffer.c b/src/plugins/irc/irc-buffer.c
index efe2d4cb6..04d221908 100644
--- a/src/plugins/irc/irc-buffer.c
+++ b/src/plugins/irc/irc-buffer.c
@@ -207,6 +207,8 @@ irc_buffer_merge_servers ()
weechat_buffer_close (ptr_buffer);
}
}
+
+ irc_server_set_buffer_title (irc_current_server);
}
}
diff --git a/src/plugins/irc/irc-command.c b/src/plugins/irc/irc-command.c
index 30edaa866..c064b3770 100644
--- a/src/plugins/irc/irc-command.c
+++ b/src/plugins/irc/irc-command.c
@@ -3178,9 +3178,10 @@ irc_command_server (void *data, struct t_gui_buffer *buffer, int argc,
}
}
}
+ irc_server_set_buffer_title (irc_current_server);
+ weechat_bar_item_update ("buffer_name");
+ weechat_bar_item_update ("input_prompt");
}
- weechat_bar_item_update ("buffer_name");
- weechat_bar_item_update ("input_prompt");
return WEECHAT_RC_OK;
}
diff --git a/src/plugins/irc/irc-protocol.c b/src/plugins/irc/irc-protocol.c
index 1e91fd9d6..bea5d7e33 100644
--- a/src/plugins/irc/irc-protocol.c
+++ b/src/plugins/irc/irc-protocol.c
@@ -2389,6 +2389,7 @@ irc_protocol_cmd_001 (struct t_irc_server *server, const char *command,
server->is_connected = 1;
server->lag_next_check = time (NULL) +
weechat_config_integer (irc_config_network_lag_check);
+ irc_server_set_buffer_title (server);
/* set away message if user was away (before disconnection for example) */
if (server->away_message && server->away_message[0])
diff --git a/src/plugins/irc/irc-server.c b/src/plugins/irc/irc-server.c
index ba5605e4a..5b1ca70f4 100644
--- a/src/plugins/irc/irc-server.c
+++ b/src/plugins/irc/irc-server.c
@@ -357,7 +357,8 @@ irc_server_init (struct t_irc_server *server)
server->addresses_count = 0;
server->addresses_array = NULL;
server->ports_array = NULL;
- server->current_address = 0;
+ server->index_current_address = 0;
+ server->current_ip = NULL;
server->sock = -1;
server->hook_connect = NULL;
server->hook_fd = NULL;
@@ -736,6 +737,8 @@ irc_server_free_data (struct t_irc_server *server)
weechat_string_free_exploded (server->addresses_array);
if (server->ports_array)
free (server->ports_array);
+ if (server->current_ip)
+ free (server->current_ip);
if (server->password)
free (server->password);
if (server->nicks)
@@ -1827,7 +1830,7 @@ irc_server_timer_cb (void *data)
&& (new_time >= ptr_server->lag_next_check))
{
irc_server_sendf (ptr_server, "PING %s",
- ptr_server->addresses_array[ptr_server->current_address]);
+ ptr_server->addresses_array[ptr_server->index_current_address]);
gettimeofday (&(ptr_server->lag_check_time), NULL);
}
@@ -1930,6 +1933,11 @@ irc_server_close_connection (struct t_irc_server *server)
/* server is now disconnected */
server->is_connected = 0;
server->ssl_connected = 0;
+ if (server->current_ip)
+ {
+ free (server->current_ip);
+ server->current_ip = NULL;
+ }
}
/*
@@ -1939,7 +1947,7 @@ irc_server_close_connection (struct t_irc_server *server)
void
irc_server_reconnect_schedule (struct t_irc_server *server)
{
- server->current_address = 0;
+ server->index_current_address = 0;
if (server->autoreconnect)
{
server->reconnect_start = time (NULL);
@@ -1978,7 +1986,7 @@ irc_server_login (struct t_irc_server *server)
server->username : "weechat",
(server->username && server->username[0]) ?
server->username : "weechat",
- server->addresses_array[server->current_address],
+ server->addresses_array[server->index_current_address],
(server->realname && server->realname[0]) ?
server->realname : "weechat");
}
@@ -1992,15 +2000,15 @@ void
irc_server_switch_address (struct t_irc_server *server)
{
if ((server->addresses_count > 1)
- && (server->current_address < server->addresses_count - 1))
+ && (server->index_current_address < server->addresses_count - 1))
{
- server->current_address++;
+ server->index_current_address++;
weechat_printf (server->buffer,
_("%s%s: switching address to %s/%d"),
irc_buffer_get_server_prefix (server, NULL),
IRC_PLUGIN_NAME,
- server->addresses_array[server->current_address],
- server->ports_array[server->current_address]);
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address]);
irc_server_connect (server, 0);
}
else
@@ -2024,12 +2032,15 @@ irc_server_connect_cb (void *arg_server, int status, const char *ip_address)
{
case WEECHAT_HOOK_CONNECT_OK:
/* login to server */
+ if (server->current_ip)
+ free (server->current_ip);
+ server->current_ip = (ip_address) ? strdup (ip_address) : NULL;
weechat_printf (server->buffer,
_("%s%s: connected to %s (%s)"),
irc_buffer_get_server_prefix (server, NULL),
IRC_PLUGIN_NAME,
- server->addresses_array[server->current_address],
- (ip_address) ? ip_address : "?");
+ server->addresses_array[server->index_current_address],
+ (server->current_ip) ? server->current_ip : "?");
irc_server_login (server);
server->hook_fd = weechat_hook_fd (server->sock,
1, 0, 0,
@@ -2043,7 +2054,7 @@ irc_server_connect_cb (void *arg_server, int status, const char *ip_address)
_("%s%s: address \"%s\" not found"),
irc_buffer_get_server_prefix (server, "error"),
IRC_PLUGIN_NAME,
- server->addresses_array[server->current_address]);
+ server->addresses_array[server->index_current_address]);
irc_server_close_connection (server);
irc_server_switch_address (server);
break;
@@ -2117,6 +2128,40 @@ irc_server_connect_cb (void *arg_server, int status, const char *ip_address)
}
/*
+ * irc_server_set_buffer_title: set title for a server buffer
+ */
+
+void
+irc_server_set_buffer_title (struct t_irc_server *server)
+{
+ char *title;
+ int length;
+
+ if (server && server->buffer)
+ {
+ if (server->is_connected)
+ {
+ length = 16 + strlen (server->addresses_array[server->index_current_address]) +
+ 16 + ((server->current_ip) ? strlen (server->current_ip) : 16) + 1;
+ title = malloc (length);
+ if (title)
+ {
+ snprintf (title, length, "IRC: %s/%d (%s)",
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address],
+ (server->current_ip) ? server->current_ip : "");
+ weechat_buffer_set (server->buffer, "title", title);
+ free (title);
+ }
+ }
+ else
+ {
+ weechat_buffer_set (server->buffer, "title", "");
+ }
+ }
+}
+
+/*
* irc_server_create_buffer: create a buffer for an IRC server
*/
@@ -2164,6 +2209,8 @@ irc_server_create_buffer (struct t_irc_server *server, int all_servers)
weechat_config_string (irc_config_look_highlight_tags));
}
+ irc_server_set_buffer_title (server);
+
return server->buffer;
}
@@ -2194,6 +2241,7 @@ irc_server_connect (struct t_irc_server *server, int disable_autojoin)
&& irc_buffer_servers)
{
server->buffer = irc_buffer_servers;
+ irc_server_set_buffer_title (server);
}
else
{
@@ -2303,8 +2351,8 @@ irc_server_connect (struct t_irc_server *server, int disable_autojoin)
"proxy %s/%d%s..."),
irc_buffer_get_server_prefix (server, NULL),
IRC_PLUGIN_NAME,
- server->addresses_array[server->current_address],
- server->ports_array[server->current_address],
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address],
(server->ipv6) ? " (IPv6)" : "",
(server->ssl) ? " (SSL)" : "",
str_proxy_type,
@@ -2313,8 +2361,8 @@ irc_server_connect (struct t_irc_server *server, int disable_autojoin)
(weechat_config_boolean (proxy_ipv6)) ? " (IPv6)" : "");
weechat_log_printf (_("Connecting to server %s/%d%s%s via %s proxy "
"%s/%d%s..."),
- server->addresses_array[server->current_address],
- server->ports_array[server->current_address],
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address],
(server->ipv6) ? " (IPv6)" : "",
(server->ssl) ? " (SSL)" : "",
str_proxy_type,
@@ -2328,15 +2376,15 @@ irc_server_connect (struct t_irc_server *server, int disable_autojoin)
_("%s%s: connecting to server %s/%d%s%s..."),
irc_buffer_get_server_prefix (server, NULL),
IRC_PLUGIN_NAME,
- server->addresses_array[server->current_address],
- server->ports_array[server->current_address],
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address],
(server->ipv6) ? " (IPv6)" : "",
(server->ssl) ? " (SSL)" : "");
weechat_log_printf (_("%s%s: connecting to server %s/%d%s%s..."),
"",
IRC_PLUGIN_NAME,
- server->addresses_array[server->current_address],
- server->ports_array[server->current_address],
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address],
(server->ipv6) ? " (IPv6)" : "",
(server->ssl) ? " (SSL)" : "");
}
@@ -2398,8 +2446,8 @@ irc_server_connect (struct t_irc_server *server, int disable_autojoin)
server->disable_autojoin = disable_autojoin;
server->hook_connect = weechat_hook_connect (server->proxy,
- server->addresses_array[server->current_address],
- server->ports_array[server->current_address],
+ server->addresses_array[server->index_current_address],
+ server->ports_array[server->index_current_address],
server->sock,
server->ipv6,
#ifdef HAVE_GNUTLS
@@ -2430,7 +2478,7 @@ irc_server_reconnect (struct t_irc_server *server)
irc_buffer_get_server_prefix (server, NULL),
IRC_PLUGIN_NAME);
server->reconnect_start = 0;
- server->current_address = 0;
+ server->index_current_address = 0;
if (irc_server_connect (server, 0))
server->reconnect_join = 1;
@@ -2489,7 +2537,7 @@ irc_server_disconnect (struct t_irc_server *server, int reconnect)
irc_buffer_get_server_prefix (server, NULL),
IRC_PLUGIN_NAME);
- server->current_address = 0;
+ server->index_current_address = 0;
if (server->nick_modes)
{
free (server->nick_modes);
@@ -2517,7 +2565,9 @@ irc_server_disconnect (struct t_irc_server *server, int reconnect)
/* discard current nick if no reconnection asked */
if (!reconnect && server->nick)
irc_server_set_nick (server, NULL);
-
+
+ irc_server_set_buffer_title (server);
+
/* send signal "irc_server_disconnected" with server name */
weechat_hook_signal_send ("irc_server_disconnected",
WEECHAT_HOOK_SIGNAL_STRING, server->name);
@@ -3019,7 +3069,7 @@ irc_server_add_to_infolist (struct t_infolist *infolist,
if (!weechat_infolist_new_var_integer (ptr_item, "autorejoin", server->autorejoin))
return 0;
- if (!weechat_infolist_new_var_integer (ptr_item, "current_address", server->current_address))
+ if (!weechat_infolist_new_var_integer (ptr_item, "index_current_address", server->index_current_address))
return 0;
if (!weechat_infolist_new_var_integer (ptr_item, "sock", server->sock))
return 0;
diff --git a/src/plugins/irc/irc-server.h b/src/plugins/irc/irc-server.h
index 1650f3637..190ec3148 100644
--- a/src/plugins/irc/irc-server.h
+++ b/src/plugins/irc/irc-server.h
@@ -82,7 +82,8 @@ struct t_irc_server
int addresses_count; /* number of addresses */
char **addresses_array; /* exploded addresses */
int *ports_array; /* ports for addresses */
- int current_address; /* current address index in array */
+ int index_current_address; /* current address index in array */
+ char *current_ip; /* current IP address */
int sock; /* socket for server (IPv4 or IPv6) */
struct t_hook *hook_connect; /* connection hook */
struct t_hook *hook_fd; /* hook for server socket */
@@ -179,6 +180,7 @@ extern void irc_server_send_signal (struct t_irc_server *server,
const char *full_message);
extern void irc_server_sendf (struct t_irc_server *server, const char *format, ...);
extern struct t_irc_server *irc_server_search (const char *server_name);
+extern void irc_server_set_buffer_title (struct t_irc_server *server);
extern struct t_gui_buffer *irc_server_create_buffer (struct t_irc_server *server,
int all_servers);
extern int irc_server_connect (struct t_irc_server *server,
diff --git a/src/plugins/irc/irc-upgrade.c b/src/plugins/irc/irc-upgrade.c
index 76d364c14..ec28e9774 100644
--- a/src/plugins/irc/irc-upgrade.c
+++ b/src/plugins/irc/irc-upgrade.c
@@ -202,7 +202,8 @@ irc_upgrade_read_cb (int object_id,
irc_current_server = irc_upgrade_current_server;
}
}
- irc_upgrade_current_server->current_address = weechat_infolist_integer (infolist, "current_address");
+ irc_upgrade_current_server->index_current_address =
+ weechat_infolist_integer (infolist, "index_current_address");
sock = weechat_infolist_integer (infolist, "sock");
if (sock >= 0)