]> granicus.if.org Git - vim/commitdiff
updated for version 7.1-258 v7.1.258
authorBram Moolenaar <Bram@vim.org>
Wed, 20 Feb 2008 12:43:01 +0000 (12:43 +0000)
committerBram Moolenaar <Bram@vim.org>
Wed, 20 Feb 2008 12:43:01 +0000 (12:43 +0000)
src/search.c

index 1ad1df31f338b7a6fa2f6d715cfaf7e37f5ae0d7..9bdd037963e97cc34f93edb06ef7feef75751183 100644 (file)
@@ -624,7 +624,7 @@ searchit(win, buf, pos, dir, pat, count, options, pat_use, stop_lnum, tm)
 #ifdef FEAT_EVAL
                    submatch = first_submatch(&regmatch);
 #endif
-                   /* Line me be past end of buffer for "\n\zs". */
+                   /* "lnum" may be past end of buffer for "\n\zs". */
                    if (lnum + matchpos.lnum > buf->b_ml.ml_line_count)
                        ptr = (char_u *)"";
                    else
@@ -833,21 +833,38 @@ searchit(win, buf, pos, dir, pat, count, options, pat_use, stop_lnum, tm)
                            continue;
                    }
 
-                   if (options & SEARCH_END && !(options & SEARCH_NOOF))
+                   /* With the SEARCH_END option move to the last character
+                    * of the match.  Don't do it for an empty match, end
+                    * should be same as start then. */
+                   if (options & SEARCH_END && !(options & SEARCH_NOOF)
+                           && !(matchpos.lnum == endpos.lnum
+                               && matchpos.col == endpos.col))
                    {
+                       /* For a match in the first column, set the position
+                        * on the NUL in the previous line. */
                        pos->lnum = lnum + endpos.lnum;
-                       pos->col = endpos.col - 1;
-#ifdef FEAT_MBYTE
-                       if (has_mbyte)
+                       pos->col = endpos.col;
+                       if (endpos.col == 0)
                        {
-                           /* 'e' offset may put us just below the last line */
-                           if (pos->lnum > buf->b_ml.ml_line_count)
-                               ptr = (char_u *)"";
-                           else
-                               ptr = ml_get_buf(buf, pos->lnum, FALSE);
-                           pos->col -= (*mb_head_off)(ptr, ptr + pos->col);
+                           if (pos->lnum > 1)  /* just in case */
+                           {
+                               --pos->lnum;
+                               pos->col = (colnr_T)STRLEN(ml_get_buf(buf,
+                                                          pos->lnum, FALSE));
+                           }
                        }
+                       else
+                       {
+                           --pos->col;
+#ifdef FEAT_MBYTE
+                           if (has_mbyte
+                                   && pos->lnum <= buf->b_ml.ml_line_count)
+                           {
+                               ptr = ml_get_buf(buf, pos->lnum, FALSE);
+                               pos->col -= (*mb_head_off)(ptr, ptr + pos->col);
+                           }
 #endif
+                       }
                    }
                    else
                    {