Blob Blame History Raw
To: vim_dev@googlegroups.com
Subject: Patch 7.4.422
Fcc: outbox
From: Bram Moolenaar <Bram@moolenaar.net>
Mime-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
------------

Patch 7.4.422
Problem:    When using conceal with linebreak some text is not displayed
	    correctly. (GrĂ¼ner Gimpel)
Solution:   Check for conceal mode when using linebreak. (Christian Brabandt)
Files:	    src/screen.c, src/testdir/test_listlbr.in,
	    src/testdir/test_listlbr.ok


*** ../vim-7.4.421/src/screen.c	2014-08-16 16:28:31.882272056 +0200
--- src/screen.c	2014-08-29 12:08:11.478423596 +0200
***************
*** 4514,4519 ****
--- 4514,4524 ----
  			int	i;
  			int	saved_nextra = n_extra;
  
+ #ifdef FEAT_CONCEAL
+ 			if (is_concealing && vcol_off > 0)
+ 			    /* there are characters to conceal */
+ 			    tab_len += vcol_off;
+ #endif
  			/* if n_extra > 0, it gives the number of chars, to
  			 * use for a tab, else we need to calculate the width
  			 * for a tab */
***************
*** 4539,4544 ****
--- 4544,4555 ----
  #endif
  			}
  			p_extra = p_extra_free;
+ #ifdef FEAT_CONCEAL
+ 			/* n_extra will be increased by FIX_FOX_BOGUSCOLS
+ 			 * macro below, so need to adjust for that here */
+ 			if (is_concealing && vcol_off > 0)
+ 			    n_extra -= vcol_off;
+ #endif
  		    }
  #endif
  #ifdef FEAT_CONCEAL
*** ../vim-7.4.421/src/testdir/test_listlbr.in	2014-07-16 17:01:38.279570568 +0200
--- src/testdir/test_listlbr.in	2014-08-29 12:03:48.126423021 +0200
***************
*** 46,51 ****
--- 46,61 ----
  :redraw!
  :let line=ScreenChar(winwidth(0))
  :call DoRecordScreen()
+ :let line="_S_\t bla"
+ :$put =line
+ :$
+ :norm! zt
+ :let g:test ="Test 5: set linebreak with conceal and set list and tab displayed by different char (line may not be truncated)"
+ :set cpo&vim list linebreak conceallevel=2 concealcursor=nv listchars=tab:ab
+ :syn match ConcealVar contained /_/ conceal
+ :syn match All /.*/ contains=ConcealVar
+ :let line=ScreenChar(winwidth(0))
+ :call DoRecordScreen()
  :%w! test.out
  :qa!
  ENDTEST
*** ../vim-7.4.421/src/testdir/test_listlbr.ok	2014-07-16 17:01:38.279570568 +0200
--- src/testdir/test_listlbr.ok	2014-08-29 12:03:48.126423021 +0200
***************
*** 25,27 ****
--- 25,34 ----
  +aaaaaaaaaaaaaaaaaa 
  ~                   
  ~                   
+ _S_	 bla
+ 
+ Test 5: set linebreak with conceal and set list and tab displayed by different char (line may not be truncated)
+ Sabbbbbb bla        
+ ~                   
+ ~                   
+ ~                   
*** ../vim-7.4.421/src/version.c	2014-08-29 11:56:21.350422045 +0200
--- src/version.c	2014-08-29 12:04:26.658423105 +0200
***************
*** 743,744 ****
--- 743,746 ----
  {   /* Add new patch number below this line */
+ /**/
+     422,
  /**/

-- 
From "know your smileys":
 ;-0	Can't find shift key
 ,-9	Kann Umschalttaste nicht finden

 /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net   \\\
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///