fix util.copyfile to deal with symlinks
authorEric St-Jean <esj@wwd.ca>
Wed, 21 Mar 2007 23:20:56 -0400
changeset 4261 1eaa8d90c689
parent 4260 29eb88bd5c8d
child 4262 ad33eeeeb50a
fix util.copyfile to deal with symlinks
mercurial/util.py
--- a/mercurial/util.py
+++ b/mercurial/util.py
@@ -614,11 +614,18 @@ def unlink(f):
 
 def copyfile(src, dest):
     "copy a file, preserving mode"
-    try:
-        shutil.copyfile(src, dest)
-        shutil.copymode(src, dest)
-    except shutil.Error, inst:
-        raise Abort(str(inst))
+    if os.path.islink(src):
+        try:
+            os.unlink(dest)
+        except:
+            pass
+        os.symlink(os.readlink(src), dest)
+    else:
+        try:
+            shutil.copyfile(src, dest)
+            shutil.copymode(src, dest)
+        except shutil.Error, inst:
+            raise Abort(str(inst))
 
 def copyfiles(src, dst, hardlink=None):
     """Copy a directory tree using hardlinks if possible"""