Merge with crew-stable
authorPatrick Mezard <pmezard@gmail.com>
Sat, 19 Jan 2008 13:19:27 +0100
changeset 5895 f1ac41359b36
parent 5894 e181665c1c79 (current diff)
parent 5879 cacfeee38870 (diff)
child 5896 ff7fb4f0db53
Merge with crew-stable
mercurial/util_win32.py
--- a/mercurial/util_win32.py	Sat Jan 19 03:06:01 2008 +0100
+++ b/mercurial/util_win32.py	Sat Jan 19 13:19:27 2008 +0100
@@ -147,9 +147,18 @@
                          self.win_strerror)
 
 def os_link(src, dst):
-    # NB will only succeed on NTFS
     try:
         win32file.CreateHardLink(dst, src)
+        # CreateHardLink sometimes succeeds on mapped drives but
+        # following nlinks() returns 1. Check it now and bail out.
+        if nlinks(src) < 2:
+            try:
+                win32file.DeleteFile(dst)
+            except:
+                pass
+            # Fake hardlinking error
+            raise WinOSError((18, 'CreateHardLink', 'The system cannot '
+                              'move the file to a different disk drive'))
     except pywintypes.error, details:
         raise WinOSError(details)