Problem: Skipping empty statusline groups is not correct.
Solution: Also set group_end_userhl. (itchyny)
/* remove group if all items are empty and highlight group
* doesn't change */
group_start_userhl = group_end_userhl = 0;
- for (n = 0; n < groupitem[groupdepth]; n++)
+ for (n = groupitem[groupdepth] - 1; n >= 0; n--)
+ {
if (item[n].type == Highlight)
- group_start_userhl = item[n].minwid;
+ {
+ group_start_userhl = group_end_userhl = item[n].minwid;
+ break;
+ }
+ }
for (n = groupitem[groupdepth] + 1; n < curitem; n++)
{
if (item[n].type == Normal)
call assert_equal(sa1, sa3)
call assert_equal(sa1, sa4)
+ let g:a = ''
+ set statusline=%#Error#{%(\ %{g:a}\ %)}
+ call assert_match('^{}\s*$', s:get_statusline())
+ let g:a = 'X'
+ call assert_match('^{ X }\s*$', s:get_statusline())
+
" %%: a percent sign.
set statusline=10%%
call assert_match('^10%\s*$', s:get_statusline())
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 1220,
/**/
1219,
/**/