summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2010-09-18 09:25:59 +0200
committerSebastien Helleu <flashcode@flashtux.org>2010-09-18 09:25:59 +0200
commit43cc44abca0768ce2ad1e804a0daa62b4ce81dfc (patch)
tree2aa40f68b3b47fab3a9003b6af6c366e9352f2ba /src
parenta20ae821da20824b3549d6c8c78d04201eda342b (diff)
downloadweechat-43cc44abca0768ce2ad1e804a0daa62b4ce81dfc.zip
Fix problem when removing relay server (socket was closed, but option relay.port.xxx not removed)
Diffstat (limited to 'src')
-rw-r--r--src/plugins/relay/relay-command.c39
-rw-r--r--src/plugins/relay/relay-config.c15
2 files changed, 40 insertions, 14 deletions
diff --git a/src/plugins/relay/relay-command.c b/src/plugins/relay/relay-command.c
index 33b315bf3..94a006f7b 100644
--- a/src/plugins/relay/relay-command.c
+++ b/src/plugins/relay/relay-command.c
@@ -151,12 +151,13 @@ relay_command_relay (void *data, struct t_gui_buffer *buffer, int argc,
char **argv, char **argv_eol)
{
struct t_relay_server *ptr_server;
+ struct t_config_option *ptr_option;
+ int port;
/* make C compiler happy */
(void) data;
(void) buffer;
- (void) argv_eol;
-
+
if (argc > 1)
{
if (weechat_strcasecmp (argv[1], "list") == 0)
@@ -180,19 +181,25 @@ relay_command_relay (void *data, struct t_gui_buffer *buffer, int argc,
{
if (argc >= 4)
{
- relay_config_create_option_port (NULL,
- relay_config_file,
- relay_config_section_port,
- argv[2],
- argv_eol[3]);
+ if (relay_config_create_option_port (NULL,
+ relay_config_file,
+ relay_config_section_port,
+ argv[2],
+ argv_eol[3]) != WEECHAT_CONFIG_OPTION_SET_ERROR)
+ {
+ weechat_printf (NULL,
+ _("%s: relay \"%s\" (port %s) added"),
+ RELAY_PLUGIN_NAME,
+ argv[2], argv_eol[3]);
+ }
}
else
{
weechat_printf (NULL,
- _("%s%s: missing arguments for \"%s\" "
- "command"),
- weechat_prefix ("error"), RELAY_PLUGIN_NAME,
- "relay add");
+ _("%s%s: missing arguments for \"%s\" "
+ "command"),
+ weechat_prefix ("error"), RELAY_PLUGIN_NAME,
+ "relay add");
}
return WEECHAT_RC_OK;
}
@@ -203,7 +210,17 @@ relay_command_relay (void *data, struct t_gui_buffer *buffer, int argc,
ptr_server = relay_server_search (argv_eol[2]);
if (ptr_server)
{
+ port = ptr_server->port;
relay_server_free (ptr_server);
+ ptr_option = weechat_config_search_option (relay_config_file,
+ relay_config_section_port,
+ argv_eol[2]);
+ if (ptr_option)
+ weechat_config_option_free (ptr_option);
+ weechat_printf (NULL,
+ _("%s: relay \"%s\" (port %d) removed"),
+ RELAY_PLUGIN_NAME,
+ argv[2], port);
}
else
{
diff --git a/src/plugins/relay/relay-config.c b/src/plugins/relay/relay-config.c
index 3dce1bae5..53b0d7e85 100644
--- a/src/plugins/relay/relay-config.c
+++ b/src/plugins/relay/relay-config.c
@@ -200,6 +200,14 @@ relay_config_create_option_port (void *data,
RELAY_PLUGIN_NAME, protocol);
rc = WEECHAT_CONFIG_OPTION_SET_ERROR;
}
+
+ if (weechat_config_search_option (config_file, section, option_name))
+ {
+ weechat_printf (NULL, _("%s%s: error: relay for \"%s\" already exists"),
+ weechat_prefix ("error"),
+ RELAY_PLUGIN_NAME, option_name);
+ rc = WEECHAT_CONFIG_OPTION_SET_ERROR;
+ }
if (rc != WEECHAT_CONFIG_OPTION_SET_ERROR)
{
@@ -226,9 +234,10 @@ relay_config_create_option_port (void *data,
&relay_config_change_port_cb, NULL,
&relay_config_delete_port_cb, NULL);
- relay_server_new (protocol_number, protocol_string, port);
-
- rc = WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE;
+ if (relay_server_new (protocol_number, protocol_string, port))
+ rc = WEECHAT_CONFIG_OPTION_SET_OK_SAME_VALUE;
+ else
+ rc = WEECHAT_CONFIG_OPTION_SET_ERROR;
}
if (protocol)