aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2016-07-13 04:04:30 -0400
committerGitHub <noreply@github.com>2016-07-13 04:04:30 -0400
commit5ea4d58a1b1d3d0cafe5da5ebe4dd64908a2a73c (patch)
tree82ce47295de86eea65a3b4f738a8af482053b587 /src
parent72ad5a16e734062046965023726791e0e35a50be (diff)
parent83aea9ccf58f66b70808ed6125eedcd9e8d9324c (diff)
downloadrneovim-5ea4d58a1b1d3d0cafe5da5ebe4dd64908a2a73c.tar.gz
rneovim-5ea4d58a1b1d3d0cafe5da5ebe4dd64908a2a73c.tar.bz2
rneovim-5ea4d58a1b1d3d0cafe5da5ebe4dd64908a2a73c.zip
Merge #5026 from joshtriplett/term-title-statusline
Please support setting terminal title in :terminal
Diffstat (limited to 'src')
-rw-r--r--src/nvim/terminal.c19
1 files changed, 13 insertions, 6 deletions
diff --git a/src/nvim/terminal.c b/src/nvim/terminal.c
index fd416b3dcc..6f50c03be9 100644
--- a/src/nvim/terminal.c
+++ b/src/nvim/terminal.c
@@ -241,6 +241,7 @@ Terminal *terminal_open(TerminalOptions opts)
set_option_value((uint8_t *)"wrap", false, NULL, OPT_LOCAL);
set_option_value((uint8_t *)"number", false, NULL, OPT_LOCAL);
set_option_value((uint8_t *)"relativenumber", false, NULL, OPT_LOCAL);
+ buf_set_term_title(curbuf, (char *)curbuf->b_ffname);
RESET_BINDING(curwin);
// Apply TermOpen autocmds so the user can configure the terminal
apply_autocmds(EVENT_TERMOPEN, NULL, NULL, false, curbuf);
@@ -618,6 +619,17 @@ static int term_movecursor(VTermPos new, VTermPos old, int visible,
return 1;
}
+static void buf_set_term_title(buf_T *buf, char *title)
+ FUNC_ATTR_NONNULL_ALL
+{
+ Error err;
+ api_free_object(dict_set_value(buf->b_vars,
+ cstr_as_string("term_title"),
+ STRING_OBJ(cstr_as_string(title)),
+ false,
+ &err));
+}
+
static int term_settermprop(VTermProp prop, VTermValue *val, void *data)
{
Terminal *term = data;
@@ -633,12 +645,7 @@ static int term_settermprop(VTermProp prop, VTermValue *val, void *data)
case VTERM_PROP_TITLE: {
buf_T *buf = handle_get_buffer(term->buf_handle);
- Error err;
- api_free_object(dict_set_value(buf->b_vars,
- cstr_as_string("term_title"),
- STRING_OBJ(cstr_as_string(val->string)),
- false,
- &err));
+ buf_set_term_title(buf, val->string);
break;
}