summaryrefslogtreecommitdiff
path: root/src/screen.c
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2009-11-03 16:20:34 +0000
committerBram Moolenaar <Bram@vim.org>2009-11-03 16:20:34 +0000
commit362f3569aeb4806860e50ef5ea633168496e0524 (patch)
tree8865033c7b864f9e1ed0bee438f73cf8146d5b74 /src/screen.c
parenta1381de5f372f404180d896389dae1aaec02875d (diff)
downloadvim-git-362f3569aeb4806860e50ef5ea633168496e0524.tar.gz
updated for version 7.2-280v7.2.280
Diffstat (limited to 'src/screen.c')
-rw-r--r--src/screen.c54
1 files changed, 36 insertions, 18 deletions
diff --git a/src/screen.c b/src/screen.c
index 28fe238d2..7570b6f11 100644
--- a/src/screen.c
+++ b/src/screen.c
@@ -132,7 +132,7 @@ static void screen_line __ARGS((int row, int coloff, int endcol, int clear_width
static void draw_vsep_win __ARGS((win_T *wp, int row));
#endif
#ifdef FEAT_STL_OPT
-static void redraw_custum_statusline __ARGS((win_T *wp));
+static void redraw_custom_statusline __ARGS((win_T *wp));
#endif
#ifdef FEAT_SEARCH_EXTRA
#define SEARCH_HL_PRIORITY 0
@@ -5772,7 +5772,7 @@ win_redr_status(wp)
else if (*p_stl != NUL || *wp->w_p_stl != NUL)
{
/* redraw custom status line */
- redraw_custum_statusline(wp);
+ redraw_custom_statusline(wp);
}
#endif
else
@@ -5897,18 +5897,31 @@ win_redr_status(wp)
* errors encountered.
*/
static void
-redraw_custum_statusline(wp)
+redraw_custom_statusline(wp)
win_T *wp;
{
- int save_called_emsg = called_emsg;
+ static int entered = FALSE;
+ int save_called_emsg = called_emsg;
+
+ /* When called recursively return. This can happen when the statusline
+ * contains an expression that triggers a redraw. */
+ if (entered)
+ return;
+ entered = TRUE;
called_emsg = FALSE;
win_redr_custom(wp, FALSE);
if (called_emsg)
+ {
+ /* When there is an error disable the statusline, otherwise the
+ * display is messed up with errors and a redraw triggers the problem
+ * again and again. */
set_string_option_direct((char_u *)"statusline", -1,
(char_u *)"", OPT_FREE | (*wp->w_p_stl != NUL
? OPT_LOCAL : OPT_GLOBAL), SID_ERROR);
+ }
called_emsg |= save_called_emsg;
+ entered = FALSE;
}
#endif
@@ -6016,6 +6029,7 @@ win_redr_custom(wp, draw_ruler)
int len;
int fillchar;
char_u buf[MAXPATHL];
+ char_u *stl;
char_u *p;
struct stl_hlrec hltab[STL_MAX_ITEM];
struct stl_hlrec tabtab[STL_MAX_ITEM];
@@ -6025,7 +6039,7 @@ win_redr_custom(wp, draw_ruler)
if (wp == NULL)
{
/* Use 'tabline'. Always at the first line of the screen. */
- p = p_tal;
+ stl = p_tal;
row = 0;
fillchar = ' ';
attr = hl_attr(HLF_TPF);
@@ -6042,17 +6056,17 @@ win_redr_custom(wp, draw_ruler)
if (draw_ruler)
{
- p = p_ruf;
+ stl = p_ruf;
/* advance past any leading group spec - implicit in ru_col */
- if (*p == '%')
+ if (*stl == '%')
{
- if (*++p == '-')
- p++;
- if (atoi((char *) p))
- while (VIM_ISDIGIT(*p))
- p++;
- if (*p++ != '(')
- p = p_ruf;
+ if (*++stl == '-')
+ stl++;
+ if (atoi((char *)stl))
+ while (VIM_ISDIGIT(*stl))
+ stl++;
+ if (*stl++ != '(')
+ stl = p_ruf;
}
#ifdef FEAT_VERTSPLIT
col = ru_col - (Columns - W_WIDTH(wp));
@@ -6081,9 +6095,9 @@ win_redr_custom(wp, draw_ruler)
else
{
if (*wp->w_p_stl != NUL)
- p = wp->w_p_stl;
+ stl = wp->w_p_stl;
else
- p = p_stl;
+ stl = p_stl;
# ifdef FEAT_EVAL
use_sandbox = was_set_insecurely((char_u *)"statusline",
*wp->w_p_stl == NUL ? 0 : OPT_LOCAL);
@@ -6098,10 +6112,14 @@ win_redr_custom(wp, draw_ruler)
if (maxwidth <= 0)
return;
+ /* Make a copy, because the statusline may include a function call that
+ * might change the option value and free the memory. */
+ stl = vim_strsave(stl);
width = build_stl_str_hl(wp == NULL ? curwin : wp,
buf, sizeof(buf),
- p, use_sandbox,
+ stl, use_sandbox,
fillchar, maxwidth, hltab, tabtab);
+ vim_free(stl);
len = (int)STRLEN(buf);
while (width < maxwidth && len < (int)sizeof(buf) - 1)
@@ -9465,7 +9483,7 @@ showruler(always)
#if defined(FEAT_STL_OPT) && defined(FEAT_WINDOWS)
if ((*p_stl != NUL || *curwin->w_p_stl != NUL) && curwin->w_status_height)
{
- redraw_custum_statusline(curwin);
+ redraw_custom_statusline(curwin);
}
else
#endif