summaryrefslogtreecommitdiffstats
path: root/source/ap/vim/patches/7.3.452
blob: 295b2fe89bf1797bc15e16e7fb4b37e1fc5e1930 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
To: vim_dev@googlegroups.com
Subject: Patch 7.3.452
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.3.452
Problem:    Undo broken when pasting close to the last line. (Andrey Radev)
Solution:   Use a flag to remember if the deleted included the last line.
	    (Christian Brabandt)
Files:	    src/ops.c


*** ../vim-7.3.451/src/ops.c	2012-01-10 13:46:18.000000000 +0100
--- src/ops.c	2012-02-22 17:32:40.000000000 +0100
***************
*** 1943,1954 ****
--- 1943,1956 ----
  	else				/* delete characters between lines */
  	{
  	    pos_T   curpos;
+ 	    int     delete_last_line;
  
  	    /* save deleted and changed lines for undo */
  	    if (u_save((linenr_T)(curwin->w_cursor.lnum - 1),
  		 (linenr_T)(curwin->w_cursor.lnum + oap->line_count)) == FAIL)
  		return FAIL;
  
+ 	    delete_last_line = (oap->end.lnum == curbuf->b_ml.ml_line_count);
  	    truncate_line(TRUE);	/* delete from cursor to end of line */
  
  	    curpos = curwin->w_cursor;	/* remember curwin->w_cursor */
***************
*** 1956,1962 ****
  	    del_lines((long)(oap->line_count - 2), FALSE);
  
  	    n = (oap->end.col + 1 - !oap->inclusive);
! 	    if (oap->inclusive && oap->end.lnum == curbuf->b_ml.ml_line_count
  		    && n > (int)STRLEN(ml_get(oap->end.lnum)))
  	    {
  		/* Special case: gH<Del> deletes the last line. */
--- 1958,1964 ----
  	    del_lines((long)(oap->line_count - 2), FALSE);
  
  	    n = (oap->end.col + 1 - !oap->inclusive);
! 	    if (oap->inclusive && delete_last_line
  		    && n > (int)STRLEN(ml_get(oap->end.lnum)))
  	    {
  		/* Special case: gH<Del> deletes the last line. */
*** ../vim-7.3.451/src/version.c	2012-02-22 16:01:53.000000000 +0100
--- src/version.c	2012-02-22 17:37:18.000000000 +0100
***************
*** 716,717 ****
--- 716,719 ----
  {   /* Add new patch number below this line */
+ /**/
+     452,
  /**/

-- 
From "know your smileys":
 =):-)	Uncle Sam

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