aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDaniel Hahler <git@thequod.de>2017-12-29 20:35:52 +0100
committerDaniel Hahler <git@thequod.de>2017-12-29 20:38:17 +0100
commite84e1b68c13443efc3e0c39a16c6a6945fbde20b (patch)
treefed164bd3fa0f624d7825fc1d04c9bd6ed17c761 /src
parent2c436b33621a3064aae94e88db90095ae69aabc8 (diff)
downloadrneovim-e84e1b68c13443efc3e0c39a16c6a6945fbde20b.tar.gz
rneovim-e84e1b68c13443efc3e0c39a16c6a6945fbde20b.tar.bz2
rneovim-e84e1b68c13443efc3e0c39a16c6a6945fbde20b.zip
Move applying of TabClosed to win_close_othertab
Diffstat (limited to 'src')
-rw-r--r--src/nvim/ex_docmd.c1
-rw-r--r--src/nvim/window.c18
2 files changed, 6 insertions, 13 deletions
diff --git a/src/nvim/ex_docmd.c b/src/nvim/ex_docmd.c
index f6a5f59676..a0ede4f3c5 100644
--- a/src/nvim/ex_docmd.c
+++ b/src/nvim/ex_docmd.c
@@ -6230,7 +6230,6 @@ void tabpage_close_other(tabpage_T *tp, int forceit)
if (!valid_tabpage(tp) || tp->tp_firstwin == wp)
break;
}
- apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, FALSE, curbuf);
redraw_tabline = TRUE;
if (h != tabline_height())
diff --git a/src/nvim/window.c b/src/nvim/window.c
index bbdf40b874..81e986c5f2 100644
--- a/src/nvim/window.c
+++ b/src/nvim/window.c
@@ -1724,7 +1724,6 @@ void close_windows(buf_T *buf, int keep_curwin)
{
tabpage_T *tp, *nexttp;
int h = tabline_height();
- int count = tabpage_index(NULL);
++RedrawingDisabled;
@@ -1741,11 +1740,6 @@ void close_windows(buf_T *buf, int keep_curwin)
} else
wp = wp->w_next;
}
- if (count != tabpage_index(NULL)) {
- char_u prev_idx[NUMBUFLEN];
- sprintf((char *)prev_idx, "%i", tabpage_index(curtab));
- apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, false, curbuf);
- }
/* Also check windows in other tab pages. */
for (tp = first_tabpage; tp != NULL; tp = nexttp) {
@@ -1762,11 +1756,6 @@ void close_windows(buf_T *buf, int keep_curwin)
break;
}
}
- if (count != tabpage_index(NULL)) {
- char_u prev_idx[NUMBUFLEN];
- sprintf((char *)prev_idx, "%i", tabpage_index(tp));
- apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, false, curbuf);
- }
}
}
@@ -1854,7 +1843,6 @@ static bool close_last_window_tabpage(win_T *win, bool free_buf,
// Since goto_tabpage_tp above did not trigger *Enter autocommands, do
// that now.
- apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, false, curbuf);
apply_autocmds(EVENT_WINENTER, NULL, NULL, false, curbuf);
apply_autocmds(EVENT_TABENTER, NULL, NULL, false, curbuf);
if (old_curbuf != curbuf) {
@@ -2114,6 +2102,10 @@ void win_close_othertab(win_T *win, int free_buf, tabpage_T *tp)
/* When closing the last window in a tab page remove the tab page. */
if (tp->tp_firstwin == tp->tp_lastwin) {
+ // save index for tabclosed event
+ char_u prev_idx[NUMBUFLEN];
+ sprintf((char *)prev_idx, "%i", tabpage_index(tp));
+
if (tp == first_tabpage)
first_tabpage = tp->tp_next;
else {
@@ -2127,6 +2119,8 @@ void win_close_othertab(win_T *win, int free_buf, tabpage_T *tp)
ptp->tp_next = tp->tp_next;
}
free_tp = TRUE;
+
+ apply_autocmds(EVENT_TABCLOSED, prev_idx, prev_idx, false, win->w_buffer);
}
/* Free the memory used for the window. */