]> granicus.if.org Git - vim/commitdiff
updated for version 7.2-076 v7.2.076
authorBram Moolenaar <Bram@vim.org>
Tue, 30 Dec 2008 15:15:57 +0000 (15:15 +0000)
committerBram Moolenaar <Bram@vim.org>
Tue, 30 Dec 2008 15:15:57 +0000 (15:15 +0000)
src/fileio.c
src/version.c

index c0dd78d47d4befbae28bf54d0488196f9382121b..39b92a6c9006902edf70d2ca382e65fbb7e90e31 100644 (file)
@@ -6119,6 +6119,47 @@ vim_rename(from, to)
     if (mch_stat((char *)from, &st) < 0)
        return -1;
 
+#ifdef UNIX
+    {
+       struct stat     st_to;
+       char            tempname[MAXPATHL + 1];
+
+       /* It's possible for the source and destination to be the same file.
+        * This happens when "from" and "to" differ in case and are on a FAT32
+        * filesystem.  In that case go through a temp file name. */
+       if (mch_stat((char *)to, &st_to) >= 0
+               && st.st_dev == st_to.st_dev
+               && st.st_ino == st_to.st_ino)
+       {
+           /* Find a name that doesn't exist and is in the same directory.
+            * Move "from" to "tempname" and then to "to". */
+           if (STRLEN(from) >= MAXPATHL - 5)
+               return -1;
+           STRCPY(tempname, from);
+           for (n = 123; n < 99999; ++n)
+           {
+               sprintf(gettail(tempname), "%d", n);
+               if (mch_stat(tempname, &st_to) < 0)
+               {
+                   if (mch_rename((char *)from, tempname) == 0)
+                   {
+                       if (mch_rename(tempname, (char *)to) == 0)
+                           return 0;
+                       /* Strange, the second step failed.  Try moving the
+                        * file back and return failure. */
+                       mch_rename(tempname, (char *)from);
+                       return -1;
+                   }
+                   /* If it fails for one temp name it will most likely fail
+                    * for any temp name, give up. */
+                   return -1;
+               }
+           }
+           return -1;
+       }
+    }
+#endif
+
     /*
      * Delete the "to" file, this is required on some systems to make the
      * mch_rename() work, on other systems it makes sure that we don't have
index 0b805e20b35e7be59dab5c8003cc8b964d4564f7..971dd62dcd60f502e2508b1725bf0bc4800aa7ad 100644 (file)
@@ -676,6 +676,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    76,
 /**/
     75,
 /**/