aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/ex_docmd.c
diff options
context:
space:
mode:
authorScott Prager <splinterofchaos@gmail.com>2015-04-15 13:05:30 -0400
committerScott Prager <splinterofchaos@gmail.com>2015-05-02 09:47:30 -0400
commit1eb33969220b267cf45adb286f0b7b6d14805eff (patch)
tree8c4e587c91bbf91748c7ace6338aa3f609eaec0f /src/nvim/ex_docmd.c
parent74aef8972048c3288a3cbd6a8dadf17a8df3c08c (diff)
downloadrneovim-1eb33969220b267cf45adb286f0b7b6d14805eff.tar.gz
rneovim-1eb33969220b267cf45adb286f0b7b6d14805eff.tar.bz2
rneovim-1eb33969220b267cf45adb286f0b7b6d14805eff.zip
unify jobstart, termopen, and system interfaces
For any of these functions, if {cmd} is a string, execute "&shell &shellcmdflag '{cmd}'", or simply {cmd} if it's a list. In termopen(), if the 'name' option is not supplied, try to guess using '{cmd}' (string) or {cmd}[0] (list). Simplify ex_terminal to use the string form of termopen(). termopen: get name from argument Convert list_to_argv to tv_to_argv. Helped-by: Björn Linse <@bfredl> Helped-by: oni-link <knil.ino@gmail.com> Helped-by: Thiago de Arruda <@tarruda>
Diffstat (limited to 'src/nvim/ex_docmd.c')
-rw-r--r--src/nvim/ex_docmd.c20
1 files changed, 8 insertions, 12 deletions
diff --git a/src/nvim/ex_docmd.c b/src/nvim/ex_docmd.c
index 656311ae14..9ff19521b6 100644
--- a/src/nvim/ex_docmd.c
+++ b/src/nvim/ex_docmd.c
@@ -9410,23 +9410,19 @@ static void ex_folddo(exarg_T *eap)
static void ex_terminal(exarg_T *eap)
{
- char *name = NULL;
- char cmd[512];
- if (strcmp((char *)eap->arg, "") == 0) {
- snprintf(cmd, sizeof(cmd), "['%s']", (char *)p_sh);
- name = (char *)p_sh;
- } else {
- // Escape quotes and slashes so they get sent literally.
+ // We will call termopen() with ['shell'] if not given a {cmd}.
+ char *name = (char *)p_sh;
+ char *lquote = "['";
+ char *rquote = "']";
+ if (*eap->arg != NUL) {
name = (char *)vim_strsave_escaped(eap->arg, (char_u *)"\"\\");
- snprintf(cmd, sizeof(cmd), "['%s','%s',\"%s\"]",
- (char *)p_sh, (char *)p_shcf, name);
+ lquote = rquote = "\"";
}
char ex_cmd[512];
snprintf(ex_cmd, sizeof(ex_cmd),
- ":enew%s | call termopen(%s, {'name':\"%s\"}) | startinsert",
- eap->forceit==TRUE ? "!" : "", cmd, name);
-
+ ":enew%s | call termopen(%s%s%s) | startinsert",
+ eap->forceit==TRUE ? "!" : "", lquote, name, rquote);
do_cmdline_cmd((uint8_t *)ex_cmd);
if (name != (char *)p_sh) {