Blob Blame History Raw
To: vim_dev@googlegroups.com
Subject: Patch 7.4.646
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.646
Problem:    ":bufdo" may start at a deleted buffer.
Solution:   Find the first not deleted buffer. (Shane Harper)
Files:	    src/ex_cmds2.c, src/testdir/test_command_count.in,
	    src/testdir/test_command_count.ok


*** ../vim-7.4.645/src/ex_cmds2.c	2015-01-07 16:52:53.506792420 +0100
--- src/ex_cmds2.c	2015-02-27 20:30:04.087096679 +0100
***************
*** 2440,2446 ****
      win_T	*wp;
      tabpage_T	*tp;
  #endif
!     buf_T	*buf;
      int		next_fnum = 0;
  #if defined(FEAT_AUTOCMD) && defined(FEAT_SYN_HL)
      char_u	*save_ei = NULL;
--- 2440,2446 ----
      win_T	*wp;
      tabpage_T	*tp;
  #endif
!     buf_T	*buf = curbuf;
      int		next_fnum = 0;
  #if defined(FEAT_AUTOCMD) && defined(FEAT_SYN_HL)
      char_u	*save_ei = NULL;
***************
*** 2493,2512 ****
  	    case CMD_argdo:
  		i = eap->line1 - 1;
  		break;
- 	    case CMD_bufdo:
- 		i = eap->line1;
- 		break;
  	    default:
  		break;
  	}
  	/* set pcmark now */
  	if (eap->cmdidx == CMD_bufdo)
! 	    goto_buffer(eap, DOBUF_FIRST, FORWARD, i);
  	else
  	    setpcmark();
  	listcmd_busy = TRUE;	    /* avoids setting pcmark below */
  
! 	while (!got_int)
  	{
  	    if (eap->cmdidx == CMD_argdo)
  	    {
--- 2493,2520 ----
  	    case CMD_argdo:
  		i = eap->line1 - 1;
  		break;
  	    default:
  		break;
  	}
  	/* set pcmark now */
  	if (eap->cmdidx == CMD_bufdo)
!         {
! 	    /* Advance to the first listed buffer after "eap->line1". */
!             for (buf = firstbuf; buf != NULL && (buf->b_fnum < eap->line1
! 					  || !buf->b_p_bl); buf = buf->b_next)
! 		if (buf->b_fnum > eap->line2)
! 		{
! 		    buf = NULL;
! 		    break;
! 		}
!             if (buf != NULL)
! 		goto_buffer(eap, DOBUF_FIRST, FORWARD, buf->b_fnum);
!         }
  	else
  	    setpcmark();
  	listcmd_busy = TRUE;	    /* avoids setting pcmark below */
  
! 	while (!got_int && buf != NULL)
  	{
  	    if (eap->cmdidx == CMD_argdo)
  	    {
*** ../vim-7.4.645/src/testdir/test_command_count.in	2015-01-27 13:28:42.472671261 +0100
--- src/testdir/test_command_count.in	2015-02-27 20:03:15.981409267 +0100
***************
*** 141,146 ****
--- 141,147 ----
  :let buffers = ''
  :.,$-bufdo let buffers .= ' '.bufnr('%')
  :call add(g:lines, 'bufdo:' . buffers)
+ :3bd
  :let buffers = ''
  :3,7bufdo let buffers .= ' '.bufnr('%')
  :call add(g:lines, 'bufdo:' . buffers)
*** ../vim-7.4.645/src/testdir/test_command_count.ok	2015-01-20 13:29:46.397315064 +0100
--- src/testdir/test_command_count.ok	2015-02-27 20:03:15.981409267 +0100
***************
*** 34,38 ****
  argdo: c d e
  windo: 2 3 4
  bufdo: 2 3 4 5 6 7 8 9 10 15
! bufdo: 3 4 5 6 7
  tabdo: 2 3 4
--- 34,38 ----
  argdo: c d e
  windo: 2 3 4
  bufdo: 2 3 4 5 6 7 8 9 10 15
! bufdo: 4 5 6 7
  tabdo: 2 3 4
*** ../vim-7.4.645/src/version.c	2015-02-27 19:34:51.464777369 +0100
--- src/version.c	2015-02-27 20:04:24.336631611 +0100
***************
*** 743,744 ****
--- 743,746 ----
  {   /* Add new patch number below this line */
+ /**/
+     646,
  /**/

-- 
The greatest lies of all time:
  (1) The check is in the mail.
  (2) We have a really challenging assignment for you.
  (3) I love you.
  (4) All bugs have been fixed.
  (5) This won't hurt a bit.
  (6) Honey, I just need to debug this program and be home in 5 minutes.
  (7) I have just sent you an e-mail about that.
  (8) Of course I'll respect you in the morning.
  (9) I'm from the government, and I'm here to help you.

 /// 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    ///