]> granicus.if.org Git - vim/commitdiff
updated for version 7.4.543 v7.4.543
authorBram Moolenaar <Bram@vim.org>
Sat, 13 Dec 2014 02:17:11 +0000 (03:17 +0100)
committerBram Moolenaar <Bram@vim.org>
Sat, 13 Dec 2014 02:17:11 +0000 (03:17 +0100)
Problem:    Since patch 7.4.232 "1,3s/\n//" joins two lines instead of three.
            (Eliseo Martínez)  Issue 287
Solution:   Correct the line count. (Christian Brabandt)
            Also set the last used search pattern.

src/ex_cmds.c
src/proto/search.pro
src/search.c
src/version.c

index 86dab4797d88555f7b49df1906e52e367032d3e6..8195eb71b80997451ea471dda4efd2b7b2eadbd9 100644 (file)
@@ -4408,6 +4408,8 @@ do_sub(eap)
            && (*cmd == NUL || (cmd[1] == NUL && (*cmd == 'g' || *cmd == 'l'
                                             || *cmd == 'p' || *cmd == '#'))))
     {
+       linenr_T    joined_lines_count;
+
        curwin->w_cursor.lnum = eap->line1;
        if (*cmd == 'l')
            eap->flags = EXFLAG_LIST;
@@ -4416,10 +4418,27 @@ do_sub(eap)
        else if (*cmd == 'p')
            eap->flags = EXFLAG_PRINT;
 
-       (void)do_join(eap->line2 - eap->line1 + 1, FALSE, TRUE, FALSE, TRUE);
-       sub_nlines = sub_nsubs = eap->line2 - eap->line1 + 1;
-       (void)do_sub_msg(FALSE);
-       ex_may_print(eap);
+       /* The number of lines joined is the number of lines in the range plus
+        * one.  One less when the last line is included. */
+       joined_lines_count = eap->line2 - eap->line1 + 1;
+       if (eap->line2 < curbuf->b_ml.ml_line_count)
+           ++joined_lines_count;
+       if (joined_lines_count > 1)
+       {
+           (void)do_join(joined_lines_count, FALSE, TRUE, FALSE, TRUE);
+           sub_nsubs = joined_lines_count - 1;
+           sub_nlines = 1;
+           (void)do_sub_msg(FALSE);
+           ex_may_print(eap);
+       }
+
+       if (!cmdmod.keeppatterns)
+           save_re_pat(RE_SUBST, pat, p_magic);
+#ifdef FEAT_CMDHIST
+       /* put pattern in history */
+       add_to_history(HIST_SEARCH, pat, TRUE, NUL);
+#endif
+
        return;
     }
 
index f94fb69ab277d1d73b62ae5a70ede3144307d5d5..07f608789ddf3432f2df0cf0d677bc2125e566d4 100644 (file)
@@ -2,6 +2,7 @@
 int search_regcomp __ARGS((char_u *pat, int pat_save, int pat_use, int options, regmmatch_T *regmatch));
 char_u *get_search_pat __ARGS((void));
 char_u *reverse_text __ARGS((char_u *s));
+void save_re_pat __ARGS((int idx, char_u *pat, int magic));
 void save_search_patterns __ARGS((void));
 void restore_search_patterns __ARGS((void));
 void free_search_patterns __ARGS((void));
index 047a733972e8fb6e044ea3891c5bca3b8879ced4..b64b8f6ce7931ff7a2c2828e11402f438367e95a 100644 (file)
@@ -12,7 +12,6 @@
 
 #include "vim.h"
 
-static void save_re_pat __ARGS((int idx, char_u *pat, int magic));
 #ifdef FEAT_EVAL
 static void set_vv_searchforward __ARGS((void));
 static int first_submatch __ARGS((regmmatch_T *rp));
@@ -272,7 +271,7 @@ reverse_text(s)
 }
 #endif
 
-    static void
+    void
 save_re_pat(idx, pat, magic)
     int                idx;
     char_u     *pat;
index 3f439802cc50547a9be6b15fefadeba02d669d4b..fe317d05325e6f7dfa0e362f55e3e681d8e5869c 100644 (file)
@@ -741,6 +741,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    543,
 /**/
     542,
 /**/