]> granicus.if.org Git - vim/commitdiff
updated for version 7.4.485 v7.4.485
authorBram Moolenaar <Bram@vim.org>
Tue, 21 Oct 2014 17:35:31 +0000 (19:35 +0200)
committerBram Moolenaar <Bram@vim.org>
Tue, 21 Oct 2014 17:35:31 +0000 (19:35 +0200)
Problem:    Abbreviations don't work. (Toothpik)
Solution:   Move the length computation inside the for loop.  Compare against
            the unescaped key.

src/getchar.c
src/version.c

index cafa660c43e16bfdb60002ff2f8d1b2b98d30b36..c9ee4d05106ffd9e6b16b5ae69461bb8a5d470ee 100644 (file)
@@ -4443,7 +4443,6 @@ check_abbr(c, ptr, col, mincol)
 #endif
     int                is_id = TRUE;
     int                vim_abbr;
-    int                qlen;           /* length of q, CSI/K_SPECIAL unescaped */
 
     if (typebuf.tb_no_abbr_cnt)        /* abbrev. are not recursive */
        return FALSE;
@@ -4521,29 +4520,34 @@ check_abbr(c, ptr, col, mincol)
 #else
        mp = first_abbr;
 #endif
-       qlen = mp->m_keylen;
-       if (vim_strbyte(mp->m_keys, K_SPECIAL) != NULL)
-       {
-           char_u      *q = vim_strsave(mp->m_keys);
-
-           /* might have CSI escaped mp->m_keys */
-           if (q != NULL)
-           {
-               vim_unescape_csi(q);
-               qlen = (int)STRLEN(q);
-               vim_free(q);
-           }
-       }
        for ( ; mp;
 #ifdef FEAT_LOCALMAP
                mp->m_next == NULL ? (mp = mp2, mp2 = NULL) :
 #endif
                (mp = mp->m_next))
        {
+           int         qlen = mp->m_keylen;
+           char_u      *q = mp->m_keys;
+           int         match;
+
+           if (vim_strbyte(mp->m_keys, K_SPECIAL) != NULL)
+           {
+               /* might have CSI escaped mp->m_keys */
+               q = vim_strsave(mp->m_keys);
+               if (q != NULL)
+               {
+                   vim_unescape_csi(q);
+                   qlen = (int)STRLEN(q);
+               }
+           }
+
            /* find entries with right mode and keys */
-           if (       (mp->m_mode & State)
+           match =    (mp->m_mode & State)
                    && qlen == len
-                   && !STRNCMP(mp->m_keys, ptr, (size_t)len))
+                   && !STRNCMP(q, ptr, (size_t)len);
+           if (q != mp->m_keys)
+               vim_free(q);
+           if (match)
                break;
        }
        if (mp != NULL)
index e0efbb6c358b6fd2b525d4b9bd833a6f905c89ea..774480c0049f3dd86df4541c3b741c197c814965 100644 (file)
@@ -741,6 +741,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    485,
 /**/
     484,
 /**/