]> granicus.if.org Git - vim/commitdiff
updated for version 7.4a.005 v7.4a.005
authorBram Moolenaar <Bram@vim.org>
Tue, 9 Jul 2013 11:44:59 +0000 (13:44 +0200)
committerBram Moolenaar <Bram@vim.org>
Tue, 9 Jul 2013 11:44:59 +0000 (13:44 +0200)
Problem:    Scroll binding causes unexpected scroll.
Solution:   Store the topline after updating scroll binding.  Add a test.
            (Lech Lorens)

src/option.c
src/testdir/Make_amiga.mak
src/testdir/Make_dos.mak
src/testdir/Make_ming.mak
src/testdir/Make_os2.mak
src/testdir/Make_vms.mms
src/testdir/Makefile
src/testdir/test98.in [new file with mode: 0644]
src/testdir/test98.ok [new file with mode: 0644]
src/testdir/test98a.in [new file with mode: 0644]
src/version.c

index e91ef5d60dea7974ab71731586871006eb3e6e7d..2f1ef11309f16af5baa8c7fb66a4f6a8ea62f9a0 100644 (file)
@@ -7801,7 +7801,10 @@ set_bool_option(opt_idx, varp, value, opt_flags)
     else if ((int *)varp == &curwin->w_p_scb)
     {
        if (curwin->w_p_scb)
+       {
            do_check_scrollbind(FALSE);
+           curwin->w_scbind_pos = curwin->w_topline;
+       }
     }
 #endif
 
index afc4a03dd3618dbcdb375aa6d7af0107a0ebf96b..0c1e9aff099f0551290da644fff39ee4e78e4376 100644 (file)
@@ -33,7 +33,7 @@ SCRIPTS = test1.out test3.out test4.out test5.out test6.out \
                test76.out test77.out test78.out test79.out test80.out \
                test81.out test82.out test83.out test84.out test88.out \
                test89.out test90.out test91.out test92.out test93.out \
-               test94.out test95.out test96.out test97.out
+               test94.out test95.out test96.out test97.out test98.out
 
 .SUFFIXES: .in .out
 
@@ -147,3 +147,4 @@ test94.out: test94.in
 test95.out: test95.in
 test96.out: test96.in
 test97.out: test97.in
+test98.out: test98.in
index 012ca8febdb5bdd66841f0222015af1432692992..a57649e5e02a3aa673c61c2f2712cfab89d49284 100644 (file)
@@ -32,7 +32,7 @@ SCRIPTS =     test3.out test4.out test5.out test6.out test7.out \
                test79.out test80.out test81.out test82.out test83.out \
                test84.out test85.out test86.out test87.out test88.out \
                test89.out test90.out test91.out test92.out test93.out \
-               test94.out test95.out test96.out
+               test94.out test95.out test96.out test98.out
 
 SCRIPTS32 =    test50.out test70.out
 
index 800603b317b3ab842f44f3788b340d88f61b146b..6c1fae0f86938af2cc135290af1a4b5092239b6e 100644 (file)
@@ -52,7 +52,7 @@ SCRIPTS =     test3.out test4.out test5.out test6.out test7.out \
                test79.out test80.out test81.out test82.out test83.out \
                test84.out test85.out test86.out test87.out test88.out \
                test89.out test90.out test91.out test92.out test93.out \
-               test94.out test95.out test96.out
+               test94.out test95.out test96.out test98.out
 
 SCRIPTS32 =    test50.out test70.out
 
index bb79c00ea5aedab52a01afd464584e8a5d52cb3c..5741f32f85912a53197f82b17dc99c17d6590904 100644 (file)
@@ -34,7 +34,7 @@ SCRIPTS = test1.out test3.out test4.out test5.out test6.out \
                test76.out test77.out test78.out test79.out test80.out \
                test81.out test82.out test83.out test84.out test88.out \
                test89.out test90.out test91.out test92.out test93.out \
-               test94.out test95.out test96.out
+               test94.out test95.out test96.out test98.out
 
 .SUFFIXES: .in .out
 
index a62b7ad4518e50b92d69cc97fb4eec0cc88c9910..e6f6fbc79a43ae180ae0f8068c59924c040610cf 100644 (file)
@@ -4,7 +4,7 @@
 # Authors:     Zoltan Arpadffy, <arpadffy@polarhome.com>
 #              Sandor Kopanyi,  <sandor.kopanyi@mailbox.hu>
 #
-# Last change:  2013 Jul 03
+# Last change:  2013 Jul 09
 #
 # This has been tested on VMS 6.2 to 8.3 on DEC Alpha, VAX and IA64.
 # Edit the lines in the Configuration section below to select.
@@ -78,7 +78,7 @@ SCRIPT = test1.out  test2.out  test3.out  test4.out  test5.out  \
         test77.out test78.out test79.out test80.out test81.out \
         test82.out test83.out test84.out test88.out test89.out \
         test90.out test91.out test92.out test93.out test94.out \
-        test95.out test96.out test97.out
+        test95.out test96.out test97.out test98.out
 
 # Known problems:
 # Test 30: a problem around mac format - unknown reason
index bc525d9d1a706dd765420f3c8fb6b814069868eb..0292dd2128772f2ca91855eb59a2511cc0022cc9 100644 (file)
@@ -29,7 +29,7 @@ SCRIPTS = test1.out test2.out test3.out test4.out test5.out test6.out \
                test79.out test80.out test81.out test82.out test83.out \
                test84.out test85.out test86.out test87.out test88.out \
                test89.out test90.out test91.out test92.out test93.out \
-               test94.out test95.out test96.out test97.out
+               test94.out test95.out test96.out test97.out test98.out
 
 SCRIPTS_GUI = test16.out
 
diff --git a/src/testdir/test98.in b/src/testdir/test98.in
new file mode 100644 (file)
index 0000000..b316017
--- /dev/null
@@ -0,0 +1,21 @@
+Test for 'scrollbind' causing an unexpected scroll of one of the windows.
+STARTTEST
+:so small.vim
+:source test98a.in
+:let topLineLeft = line('w0')
+:wincmd p
+:let topLineRight = line('w0')
+:setl noscrollbind
+:wincmd p
+:setl noscrollbind
+:q!
+:%del _
+:call setline(1, 'Difference between the top lines (left - right): ' . string(topLineLeft - topLineRight))
+:w! test.out
+:brewind
+ENDTEST
+
+STARTTEST
+:qa!
+ENDTEST
+
diff --git a/src/testdir/test98.ok b/src/testdir/test98.ok
new file mode 100644 (file)
index 0000000..356ddd8
--- /dev/null
@@ -0,0 +1 @@
+Difference between the top lines (left - right): 0
diff --git a/src/testdir/test98a.in b/src/testdir/test98a.in
new file mode 100644 (file)
index 0000000..4999c28
--- /dev/null
@@ -0,0 +1,27 @@
+" We don't want the status line to cause problems:
+set laststatus=0
+redraw!
+let g:totalLines = &lines * 20
+let middle = g:totalLines / 2
+wincmd n
+wincmd o
+for i in range(1, g:totalLines)
+       call setline(i, 'LINE ' . i)
+endfor
+
+exe string(middle)
+normal zt
+normal M
+
+aboveleft vert new
+for i in range(1, g:totalLines)
+       call setline(i, 'line ' . i)
+endfor
+exe string(middle)
+normal zt
+normal M
+setl scb
+
+wincmd p
+
+call feedkeys(":setl scb\n\<C-w>\<C-w>", 't')
index ad4e4412cb11b7579441142600d3e5cedeae4060..25534c57ce4f5d6a92d9192f45cef062e82b9a3a 100644 (file)
@@ -728,6 +728,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    5,
 /**/
     4,
 /**/