diff options
author | Drew DeVault <sir@cmpwn.com> | 2016-01-24 18:33:06 -0500 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2016-01-24 18:33:06 -0500 |
commit | 55ac868898df8acc790dcd2ec56e294e89df5ea1 (patch) | |
tree | b4f10872f5182c8db7fa9629d1567e34e8373ef1 | |
parent | ed227f5664196d85194d63d01a5382499867a386 (diff) | |
parent | 32ae26e519eeb6a5108f1d82fe36ce5b6ef65af3 (diff) | |
download | sway-55ac868898df8acc790dcd2ec56e294e89df5ea1.tar.xz |
Merge pull request #471 from mikkeloscar/fix-exec-quotes
Add quotes to multiword arguments.
-rw-r--r-- | common/stringop.c | 26 | ||||
-rw-r--r-- | include/stringop.h | 5 | ||||
-rw-r--r-- | sway/commands.c | 2 |
3 files changed, 33 insertions, 0 deletions
diff --git a/common/stringop.c b/common/stringop.c index 81d9b963..186fe121 100644 --- a/common/stringop.c +++ b/common/stringop.c @@ -273,6 +273,32 @@ char *join_args(char **argv, int argc) { return res; } +static bool has_whitespace(const char *str) { + while (*str) { + if (isspace(*str)) { + return true; + } + ++str; + } + return false; +} + +/** + * Add quotes around any argv with whitespaces. + */ +void add_quotes(char **argv, int argc) { + int i; + for (i = 0; i < argc; ++i) { + if (has_whitespace(argv[i])) { + int len = strlen(argv[i]) + 3; + char *tmp = argv[i]; + argv[i] = malloc(len * sizeof(char)); + snprintf(argv[i], len, "\"%s\"", tmp); + free(tmp); + } + } +} + /* * Join a list of strings, adding separator in between. Separator can be NULL. */ diff --git a/include/stringop.h b/include/stringop.h index bb681bcd..7c29a745 100644 --- a/include/stringop.h +++ b/include/stringop.h @@ -31,6 +31,11 @@ int unescape_string(char *string); char *join_args(char **argv, int argc); char *join_list(list_t *list, char *separator); +/** + * Add quotes around any argv with whitespaces. + */ +void add_quotes(char **argv, int argc); + // split string into 2 by delim. char *cmdsep(char **stringp, const char *delim); // Split string into 2 by delim, handle quotes diff --git a/sway/commands.c b/sway/commands.c index 9f6e5032..ae5c48e6 100644 --- a/sway/commands.c +++ b/sway/commands.c @@ -361,8 +361,10 @@ static struct cmd_results *cmd_exec_always(int argc, char **argv) { return error; } + add_quotes(argv + 1, argc - 1); tmp = join_args(argv + 1, argc - 1); } else { + add_quotes(argv, argc); tmp = join_args(argv, argc); } |