diff options
author | Bram Moolenaar <Bram@vim.org> | 2013-04-12 14:42:39 +0200 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2013-04-12 14:42:39 +0200 |
commit | 38ec50bea8ecb60fa4dd50cfca7c29c98a7a8df0 (patch) | |
tree | 72871db4faba143134dcf04963bb0daa4766274a | |
parent | e3e6e573d10760a808e02514c350f136e9d9c7e4 (diff) | |
download | vim-git-38ec50bea8ecb60fa4dd50cfca7c29c98a7a8df0.tar.gz |
updated for version 7.3.888v7.3.888
Problem: Filename completion with 'fileignorecase' does not work for
multi-byte characters.
Solution: Make 'fileignorecase' work properly. (Hirohito Higashi)
-rw-r--r-- | src/misc2.c | 33 | ||||
-rw-r--r-- | src/version.c | 2 |
2 files changed, 22 insertions, 13 deletions
diff --git a/src/misc2.c b/src/misc2.c index bfffd2e8e..550ab4d35 100644 --- a/src/misc2.c +++ b/src/misc2.c @@ -6099,52 +6099,59 @@ pathcmp(p, q, maxlen) int maxlen; { int i; + int c1, c2; const char *s = NULL; - for (i = 0; maxlen < 0 || i < maxlen; ++i) + for (i = 0; maxlen < 0 || i < maxlen; i += MB_PTR2LEN((char_u *)p + i)) { + c1 = PTR2CHAR((char_u *)p + i); + c2 = PTR2CHAR((char_u *)q + i); + /* End of "p": check if "q" also ends or just has a slash. */ - if (p[i] == NUL) + if (c1 == NUL) { - if (q[i] == NUL) /* full match */ + if (c2 == NUL) /* full match */ return 0; s = q; break; } /* End of "q": check if "p" just has a slash. */ - if (q[i] == NUL) + if (c2 == NUL) { s = p; break; } - if ((p_fic ? TOUPPER_LOC(p[i]) != TOUPPER_LOC(q[i]) : p[i] != q[i]) + if ((p_fic ? MB_TOUPPER(c1) != MB_TOUPPER(c2) : c1 != c2) #ifdef BACKSLASH_IN_FILENAME /* consider '/' and '\\' to be equal */ - && !((p[i] == '/' && q[i] == '\\') - || (p[i] == '\\' && q[i] == '/')) + && !((c1 == '/' && c2 == '\\') + || (c1 == '\\' && c2 == '/')) #endif ) { - if (vim_ispathsep(p[i])) + if (vim_ispathsep(c1)) return -1; - if (vim_ispathsep(q[i])) + if (vim_ispathsep(c2)) return 1; - return ((char_u *)p)[i] - ((char_u *)q)[i]; /* no match */ + return p_fic ? MB_TOUPPER(c1) - MB_TOUPPER(c2) + : c1 - c2; /* no match */ } } if (s == NULL) /* "i" ran into "maxlen" */ return 0; + c1 = PTR2CHAR((char_u *)s + i); + c2 = PTR2CHAR((char_u *)s + i + MB_PTR2LEN((char_u *)s + i)); /* ignore a trailing slash, but not "//" or ":/" */ - if (s[i + 1] == NUL + if (c2 == NUL && i > 0 && !after_pathsep((char_u *)s, (char_u *)s + i) #ifdef BACKSLASH_IN_FILENAME - && (s[i] == '/' || s[i] == '\\') + && (c1 == '/' || c1 == '\\') #else - && s[i] == '/' + && c1 == '/' #endif ) return 0; /* match with trailing slash */ diff --git a/src/version.c b/src/version.c index bf6385a08..bc16d2b20 100644 --- a/src/version.c +++ b/src/version.c @@ -729,6 +729,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 888, +/**/ 887, /**/ 886, |