aboutsummaryrefslogtreecommitdiff
path: root/src/os_unix.c
diff options
context:
space:
mode:
authorThiago de Arruda <tpadilha84@gmail.com>2014-03-29 14:28:44 -0300
committerThiago de Arruda <tpadilha84@gmail.com>2014-03-31 08:07:47 -0300
commitf496d619a9744a2b71f358babe1c5bed969a04ff (patch)
tree45ef0d4aa4b5a3528946eac7946abb09722e5fcd /src/os_unix.c
parentc7919222249812947daa04d6d266b6aa561e5ef3 (diff)
downloadrneovim-f496d619a9744a2b71f358babe1c5bed969a04ff.tar.gz
rneovim-f496d619a9744a2b71f358babe1c5bed969a04ff.tar.bz2
rneovim-f496d619a9744a2b71f358babe1c5bed969a04ff.zip
Extract `shell_build_argv` from `mch_call_shell`
Diffstat (limited to 'src/os_unix.c')
-rw-r--r--src/os_unix.c45
1 files changed, 4 insertions, 41 deletions
diff --git a/src/os_unix.c b/src/os_unix.c
index d53ddac830..eb960cef00 100644
--- a/src/os_unix.c
+++ b/src/os_unix.c
@@ -1721,51 +1721,14 @@ int mch_call_shell(char_u *cmd, int options, char_u *extra_shell_arg)
// Count the number of arguments for the shell
p = newcmd;
argc = shell_count_argc(&p);
-
- // Allocate argv memory
- argv = (char **)alloc((unsigned)((argc + 4) * sizeof(char *)));
- if (argv == NULL) // out of memory
- goto error;
-
- // Build argv[]
p = newcmd;
- argc = 0;
- while (true) {
- argv[argc] = (char *)p;
- ++argc;
- shell_skip_word(&p);
- if (*p == NUL)
- break;
- // Terminate the word
- *p++ = NUL;
- p = skipwhite(p);
- }
- if (cmd != NULL) {
- char_u *s;
-
- if (extra_shell_arg != NULL)
- argv[argc++] = (char *)extra_shell_arg;
-
- /* Break 'shellcmdflag' into white separated parts. This doesn't
- * handle quoted strings, they are very unlikely to appear. */
- p_shcf_copy = alloc((unsigned)STRLEN(p_shcf) + 1);
- if (p_shcf_copy == NULL) /* out of memory */
- goto error;
- s = p_shcf_copy;
- p = p_shcf;
- while (*p != NUL) {
- argv[argc++] = (char *)s;
- while (*p && *p != ' ' && *p != TAB)
- *s++ = *p++;
- *s++ = NUL;
- p = skipwhite(p);
- }
+ argv = shell_build_argv(argc, cmd, extra_shell_arg, &p, &p_shcf_copy);
- argv[argc++] = (char *)cmd;
+ if (argv == NULL) {
+ goto error;
}
- argv[argc] = NULL;
- /*
+ /*
* For the GUI, when writing the output into the buffer and when reading
* input from the buffer: Try using a pseudo-tty to get the stdin/stdout
* of the executed command into the Vim window. Or use a pipe.