]> granicus.if.org Git - vim/commitdiff
updated for version 7.4.505 v7.4.505
authorBram Moolenaar <Bram@vim.org>
Wed, 5 Nov 2014 17:36:03 +0000 (18:36 +0100)
committerBram Moolenaar <Bram@vim.org>
Wed, 5 Nov 2014 17:36:03 +0000 (18:36 +0100)
Problem:    On MS-Windows when 'encoding' is a double-byte encoding a file
            name longer than MAX_PATH bytes but shorter than that in
            characters causes problems.
Solution:   Fail on file names longer than MAX_PATH bytes. (Ken Takata)

src/os_win32.c
src/version.c

index c03b963c4fe5796ecd1206580e98486b1a68c548..fcfafa01e89ba4daeba1961bac34216e64420fe0 100644 (file)
@@ -6139,6 +6139,13 @@ mch_open(char *name, int flags, int mode)
     }
 # endif
 
+    /* open() can open a file which name is longer than _MAX_PATH bytes
+     * and shorter than _MAX_PATH characters successfully, but sometimes it
+     * causes unexpected error in another part. We make it an error explicitly
+     * here. */
+    if (strlen(name) >= _MAX_PATH)
+       return -1;
+
     return open(name, flags, mode);
 }
 
@@ -6188,6 +6195,13 @@ mch_fopen(char *name, char *mode)
         * the _wfopen() fails for missing wide functions. */
     }
 
+    /* fopen() can open a file which name is longer than _MAX_PATH bytes
+     * and shorter than _MAX_PATH characters successfully, but sometimes it
+     * causes unexpected error in another part. We make it an error explicitly
+     * here. */
+    if (strlen(name) >= _MAX_PATH)
+       return NULL;
+
     return fopen(name, mode);
 }
 #endif
index 4bbc221552522867bed9a34aaa97116156a455bd..178a7845f269f3d024145d88324444d92f417523 100644 (file)
@@ -741,6 +741,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    505,
 /**/
     504,
 /**/