patch 8.2.1979: "term_opencmd" option of term_start() is truncated
Problem: "term_opencmd" option of term_start() is truncated. (Sergey
Vlasov)
Solution: Allocate the buffer to hold the command. (closes #7284)
diff --git a/src/terminal.c b/src/terminal.c
index 0fb9f48..4e2ff14 100644
--- a/src/terminal.c
+++ b/src/terminal.c
@@ -3450,15 +3450,19 @@
if (term->tl_finish == TL_FINISH_OPEN
&& term->tl_buffer->b_nwindows == 0)
{
- char buf[50];
+ char *cmd = term->tl_opencmd == NULL
+ ? "botright sbuf %d"
+ : (char *)term->tl_opencmd;
+ size_t len = strlen(cmd) + 50;
+ char *buf = alloc(len);
- // TODO: use term_opencmd
- ch_log(NULL, "terminal job finished, opening window");
- vim_snprintf(buf, sizeof(buf),
- term->tl_opencmd == NULL
- ? "botright sbuf %d"
- : (char *)term->tl_opencmd, fnum);
- do_cmdline_cmd((char_u *)buf);
+ if (buf != NULL)
+ {
+ ch_log(NULL, "terminal job finished, opening window");
+ vim_snprintf(buf, len, cmd, fnum);
+ do_cmdline_cmd((char_u *)buf);
+ vim_free(buf);
+ }
}
else
ch_log(NULL, "terminal job finished");