summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/core/servers.c12
-rw-r--r--src/core/special-vars.c28
2 files changed, 28 insertions, 12 deletions
diff --git a/src/core/servers.c b/src/core/servers.c
index 9ec53902..fa9e6666 100644
--- a/src/core/servers.c
+++ b/src/core/servers.c
@@ -429,12 +429,14 @@ SERVER_REC *cmd_options_get_server(const char *cmd,
/* get all the options, then remove the known ones. there should
be only one left - the server tag. */
list = hashtable_get_keys(optlist);
- for (tmp = list; tmp != NULL; tmp = next) {
- char *option = tmp->data;
- next = tmp->next;
+ if (cmd != NULL) {
+ for (tmp = list; tmp != NULL; tmp = next) {
+ char *option = tmp->data;
+ next = tmp->next;
- if (command_have_option(cmd, option))
- list = g_slist_remove(list, option);
+ if (command_have_option(cmd, option))
+ list = g_slist_remove(list, option);
+ }
}
if (list == NULL)
diff --git a/src/core/special-vars.c b/src/core/special-vars.c
index 0b83658f..72949c18 100644
--- a/src/core/special-vars.c
+++ b/src/core/special-vars.c
@@ -476,9 +476,14 @@ void eval_special_string(const char *cmd, const char *data,
{
const char *cmdchars;
char *orig, *str, *start, *ret;
- int arg_used;
+ int arg_used, arg_used_ever;
+ GSList *commands;
+ commands = NULL;
+ arg_used_ever = FALSE;
cmdchars = settings_get_str("cmdchars");
+
+ /* get a list of all the commands to run */
orig = start = str = g_strdup(cmd);
do {
if (is_split_char(str, start))
@@ -490,6 +495,8 @@ void eval_special_string(const char *cmd, const char *data,
ret = parse_special_string(start, server, item,
data, &arg_used);
+ if (arg_used) arg_used_ever = TRUE;
+
if (strchr(cmdchars, *ret) == NULL) {
/* no command char - let's put it there.. */
char *old = ret;
@@ -497,19 +504,26 @@ void eval_special_string(const char *cmd, const char *data,
ret = g_strdup_printf("%c%s", *cmdchars, old);
g_free(old);
}
- if (!arg_used && *data != '\0') {
- /* append the string with all the arguments */
+ commands = g_slist_append(commands, ret);
+ start = str;
+ } while (*start != '\0');
+
+ /* run the command, if no arguments were ever used, append all of them
+ after each command */
+ while (commands != NULL) {
+ ret = commands->data;
+
+ if (!arg_used_ever && *data != '\0') {
char *old = ret;
ret = g_strconcat(old, " ", data, NULL);
g_free(old);
}
signal_emit("send command", 3, ret, server, item);
- g_free(ret);
-
- start = str;
- } while (*start != '\0');
+ g_free(ret);
+ commands = g_slist_remove(commands, commands->data);
+ }
g_free(orig);
}