Blame SOURCES/7.4.594

22c937
To: vim_dev@googlegroups.com
22c937
Subject: Patch 7.4.594
22c937
Fcc: outbox
22c937
From: Bram Moolenaar <Bram@moolenaar.net>
22c937
Mime-Version: 1.0
22c937
Content-Type: text/plain; charset=UTF-8
22c937
Content-Transfer-Encoding: 8bit
22c937
------------
22c937
22c937
Patch 7.4.594
22c937
Problem:    Using a block delete while 'breakindent' is set does not work
22c937
	    properly.
22c937
Solution:   Use "line" instead of "prev_pend" as the first argument to
22c937
	    lbr_chartabsize_adv().  (Hirohito Higashi)
22c937
Files:	    src/ops.c, src/testdir/test_breakindent.in,
22c937
	    src/testdir/test_breakindent.ok
22c937
22c937
22c937
*** ../vim-7.4.593/src/ops.c	2015-01-18 14:08:52.699436994 +0100
22c937
--- src/ops.c	2015-01-27 13:07:11.518790582 +0100
22c937
***************
22c937
*** 5308,5317 ****
22c937
  	    {
22c937
  		/* Count a tab for what it's worth (if list mode not on) */
22c937
  		prev_pend = pend;
22c937
! 		/* TODO: is passing prev_pend for start of the line OK?
22c937
! 		 * perhaps it should be "line". */
22c937
! 		incr = lbr_chartabsize_adv(prev_pend, &pend,
22c937
! 						      (colnr_T)bdp->end_vcol);
22c937
  		bdp->end_vcol += incr;
22c937
  	    }
22c937
  	    if (bdp->end_vcol <= oap->end_vcol
22c937
--- 5308,5314 ----
22c937
  	    {
22c937
  		/* Count a tab for what it's worth (if list mode not on) */
22c937
  		prev_pend = pend;
22c937
! 		incr = lbr_chartabsize_adv(line, &pend, (colnr_T)bdp->end_vcol);
22c937
  		bdp->end_vcol += incr;
22c937
  	    }
22c937
  	    if (bdp->end_vcol <= oap->end_vcol
22c937
*** ../vim-7.4.593/src/testdir/test_breakindent.in	2014-11-27 14:09:09.490354943 +0100
22c937
--- src/testdir/test_breakindent.in	2015-01-27 13:06:51.067014258 +0100
22c937
***************
22c937
*** 99,104 ****
22c937
--- 99,121 ----
22c937
  :$put =line1
22c937
  :$put =line2
22c937
  :"
22c937
+ :let g:test="Test 14: breakindent + visual blockwise delete #1"
22c937
+ :set all& breakindent
22c937
+ :30vnew
22c937
+ :normal! 3a1234567890
22c937
+ :normal! a    abcde
22c937
+ :exec "normal! 0\<C-V>tex"
22c937
+ :let line1=ScreenChar(line('.'),8)
22c937
+ :call DoRecordScreen()
22c937
+ :"
22c937
+ :let g:test="Test 15: breakindent + visual blockwise delete #2"
22c937
+ :%d
22c937
+ :normal! 4a1234567890
22c937
+ :exec "normal! >>\<C-V>3f0x"
22c937
+ :let line1=ScreenChar(line('.'),20)
22c937
+ :call DoRecordScreen()
22c937
+ :quit!
22c937
+ :"
22c937
  :%w! test.out
22c937
  :qa!
22c937
  ENDTEST
22c937
*** ../vim-7.4.593/src/testdir/test_breakindent.ok	2014-11-27 14:09:09.490354943 +0100
22c937
--- src/testdir/test_breakindent.ok	2015-01-27 13:06:51.067014258 +0100
22c937
***************
22c937
*** 62,64 ****
22c937
--- 62,74 ----
22c937
  Test 13: breakindent with wrapping Tab
22c937
  d
22c937
  w
22c937
+ 
22c937
+ Test 14: breakindent + visual blockwise delete #1
22c937
+ e       
22c937
+ ~       
22c937
+ ~       
22c937
+ 
22c937
+ Test 15: breakindent + visual blockwise delete #2
22c937
+         1234567890  
22c937
+ ~                   
22c937
+ ~                   
22c937
*** ../vim-7.4.593/src/version.c	2015-01-27 12:59:51.859602392 +0100
22c937
--- src/version.c	2015-01-27 13:10:18.260748209 +0100
22c937
***************
22c937
*** 743,744 ****
22c937
--- 743,746 ----
22c937
  {   /* Add new patch number below this line */
22c937
+ /**/
22c937
+     594,
22c937
  /**/
22c937
22c937
-- 
22c937
hundred-and-one symptoms of being an internet addict:
22c937
122. You ask if the Netaholics Anonymous t-shirt you ordered can be
22c937
     sent to you via e-mail.
22c937
22c937
 /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net   \\\
22c937
///        sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
22c937
\\\  an exciting new programming language -- http://www.Zimbu.org        ///
22c937
 \\\            help me help AIDS victims -- http://ICCF-Holland.org    ///