]> granicus.if.org Git - vim/commitdiff
updated for version 7.4.662 v7.4.662
authorBram Moolenaar <Bram@vim.org>
Fri, 13 Mar 2015 14:03:00 +0000 (15:03 +0100)
committerBram Moolenaar <Bram@vim.org>
Fri, 13 Mar 2015 14:03:00 +0000 (15:03 +0100)
Problem:    When 'M' is in the 'cpo' option then selecting a text object in
            parenthesis does not work correctly.
Solution:   Keep 'M' in 'cpo' when finding a match. (Hirohito Higashi)

src/search.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/test_textobjects.in [new file with mode: 0644]
src/testdir/test_textobjects.ok [new file with mode: 0644]
src/version.c

index 8beacbbc3fa52f7ada711951d0fdcfa0d8ad2ef1..7022870c4c91815a67caa6499e2a9119706f1138 100644 (file)
@@ -3583,10 +3583,11 @@ current_block(oap, count, include, what, other)
     /*
      * Search backwards for unclosed '(', '{', etc..
      * Put this position in start_pos.
-     * Ignore quotes here.
+     * Ignore quotes here.  Keep the "M" flag in 'cpo', as that is what the
+     * user wants.
      */
     save_cpo = p_cpo;
-    p_cpo = (char_u *)"%";
+    p_cpo = (char_u *)(vim_strchr(p_cpo, CPO_MATCHBSL) != NULL ? "%M" : "%");
     while (count-- > 0)
     {
        if ((pos = findmatch(NULL, what)) == NULL)
index 2567d52e75ae0008d79310d86075f2cdc62e04cb..cc4af8934bcf91ba41e6e7398d08a8f9d1ef52ec 100644 (file)
@@ -53,6 +53,7 @@ SCRIPTS = test1.out test3.out test4.out test5.out test6.out \
                test_options.out \
                test_qf_title.out \
                test_signs.out \
+               test_textobjects.out \
                test_utf8.out
 
 .SUFFIXES: .in .out
@@ -194,4 +195,5 @@ test_nested_function.out: test_nested_function.in
 test_options.out: test_options.in
 test_qf_title.out: test_qf_title.in
 test_signs.out: test_signs.in
+test_textobjects.out: test_textobjects.in
 test_utf8.out: test_utf8.in
index 4b17f96f4ba4607a1986731421afaa1bb9f84e8b..fcd81b54dfa22def4ffa39a9bf9aa0bbd0108b69 100644 (file)
@@ -52,6 +52,7 @@ SCRIPTS =     test3.out test4.out test5.out test6.out test7.out \
                test_options.out \
                test_qf_title.out \
                test_signs.out \
+               test_textobjects.out \
                test_utf8.out
 
 SCRIPTS32 =    test50.out test70.out
index a907fb123a6bf886e00953dceedaf98cefdb6ae5..3e6a50fb415203e07ec98d1254801e76dd0e56a6 100644 (file)
@@ -74,6 +74,7 @@ SCRIPTS =     test3.out test4.out test5.out test6.out test7.out \
                test_options.out \
                test_qf_title.out \
                test_signs.out \
+               test_textobjects.out \
                test_utf8.out
 
 SCRIPTS32 =    test50.out test70.out
index bab000d7c00f9539df84ac73b93e1c0b1783f1f5..31023ea85e80494c3f61cdddda959be715a46d59 100644 (file)
@@ -54,6 +54,7 @@ SCRIPTS = test1.out test3.out test4.out test5.out test6.out \
                test_options.out \
                test_qf_title.out \
                test_signs.out \
+               test_textobjects.out \
                test_utf8.out
 
 SCRIPTS_BENCH = bench_re_freeze.out
index ab1e529ea0103f6f2f0f84494a8e0d40d3a195bb..7448d724fc50aa88d4f91d67b63aadebd2b2c84f 100644 (file)
@@ -4,7 +4,7 @@
 # Authors:     Zoltan Arpadffy, <arpadffy@polarhome.com>
 #              Sandor Kopanyi,  <sandor.kopanyi@mailbox.hu>
 #
-# Last change:  2014 Dec 13
+# Last change:  2015 Mar 13
 #
 # 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.
@@ -113,6 +113,7 @@ SCRIPT = test1.out  test2.out  test3.out  test4.out  test5.out  \
         test_options.out \
         test_qf_title.out \
         test_signs.out \
+        test_textobjects.out \
         test_utf8.out
 
 # Known problems:
index 626c81e8d56954ec8225a059a76fb64246ae9ada..966183686e588fe1061fc88deb21241f789d0e70 100644 (file)
@@ -50,6 +50,7 @@ SCRIPTS = test1.out test2.out test3.out test4.out test5.out test6.out \
                test_options.out \
                test_qf_title.out \
                test_signs.out \
+               test_textobjects.out \
                test_utf8.out
 
 SCRIPTS_GUI = test16.out
diff --git a/src/testdir/test_textobjects.in b/src/testdir/test_textobjects.in
new file mode 100644 (file)
index 0000000..d1cdafc
--- /dev/null
@@ -0,0 +1,40 @@
+Tests for text-objects     vim: set ft=vim :
+
+STARTTEST
+:so small.vim
+:if !has('textobjects') | e! test.ok | wq! test.out | endif
+:set nocompatible
+:"
+:function SelectionOut(data)
+:  new
+:  call setline(1, a:data)
+:  call setreg('"', '')
+:  normal! ggfrmavi)y
+:  $put =getreg('\"')
+:  call setreg('"', '')
+:  normal! `afbmavi)y
+:  $put =getreg('\"')
+:  call setreg('"', '')
+:  normal! `afgmavi)y
+:  $put =getreg('\"')
+:  %yank a
+:  q!
+:  $put =getreg('a')
+:endfunction
+:"
+:$put ='# Test for vi) without cpo-M'
+:set cpo-=M
+:call SelectionOut('(red \(blue) green)')
+:"
+:$put ='# Test for vi) with cpo-M #1'
+:set cpo+=M
+:call SelectionOut('(red \(blue) green)')
+:"
+:$put ='# Test for vi) with cpo-M #2'
+:set cpo+=M
+:call SelectionOut('(red (blue\) green)')
+:/^Results/,$w test.out
+:qa!
+ENDTEST
+
+Results of text-objects
diff --git a/src/testdir/test_textobjects.ok b/src/testdir/test_textobjects.ok
new file mode 100644 (file)
index 0000000..b670c7d
--- /dev/null
@@ -0,0 +1,16 @@
+Results of text-objects
+# Test for vi) without cpo-M
+(red \(blue) green)
+red \(blue
+red \(blue
+
+# Test for vi) with cpo-M #1
+(red \(blue) green)
+red \(blue) green
+blue
+red \(blue) green
+# Test for vi) with cpo-M #2
+(red (blue\) green)
+red (blue\) green
+blue\
+red (blue\) green
index e523a41d17917b53f54909a9d5bc0fc0461b67a0..5bb8a4c34b2bb78e4312ca968464f6074da78bda 100644 (file)
@@ -741,6 +741,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    662,
 /**/
     661,
 /**/