summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2010-07-12 21:38:19 +0200
committerBram Moolenaar <Bram@vim.org>2010-07-12 21:38:19 +0200
commit1c727d82089b71c1efb40133a4e356acd7cb055e (patch)
tree68d2fc3c6e597f2196e4545ed22736f32f5747b7
parent84e67dfa9c1de3df4073187144fb7c5605cbfb4d (diff)
downloadvim-git-1c727d82089b71c1efb40133a4e356acd7cb055e.tar.gz
updated for version 7.2.446v7.2.446
Problem: Crash in GUI when closing the last window in a tabpage. (ryo7000) Solution: Remove the tabpage from the list before freeing the window.
-rw-r--r--src/version.c2
-rw-r--r--src/window.c14
2 files changed, 11 insertions, 5 deletions
diff --git a/src/version.c b/src/version.c
index c00969722..19e64ddef 100644
--- a/src/version.c
+++ b/src/version.c
@@ -682,6 +682,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 446,
+/**/
445,
/**/
444,
diff --git a/src/window.c b/src/window.c
index cc114ccad..1dccb5a7b 100644
--- a/src/window.c
+++ b/src/window.c
@@ -2304,6 +2304,7 @@ win_close_othertab(win, free_buf, tp)
win_T *wp;
int dir;
tabpage_T *ptp = NULL;
+ int free_tp = FALSE;
/* Close the link to the buffer. */
close_buffer(win, win->w_buffer, free_buf ? DOBUF_UNLOAD : 0);
@@ -2321,11 +2322,8 @@ win_close_othertab(win, free_buf, tp)
if (wp == NULL)
return;
- /* Free the memory used for the window. */
- wp = win_free_mem(win, &dir, tp);
-
/* When closing the last window in a tab page remove the tab page. */
- if (wp == NULL)
+ if (tp == NULL ? firstwin == lastwin : tp->tp_firstwin == tp->tp_lastwin)
{
if (tp == first_tabpage)
first_tabpage = tp->tp_next;
@@ -2341,8 +2339,14 @@ win_close_othertab(win, free_buf, tp)
}
ptp->tp_next = tp->tp_next;
}
- free_tabpage(tp);
+ free_tp = TRUE;
}
+
+ /* Free the memory used for the window. */
+ win_free_mem(win, &dir, tp);
+
+ if (free_tp)
+ free_tabpage(tp);
}
/*