mercurial/dirstate.py
changeset 24632 b2fb1403994e
parent 24610 4a4018831d2e
parent 24621 1784ca148392
child 24635 21e1ece30f8c
--- a/mercurial/dirstate.py	Sat Apr 04 19:06:43 2015 -0400
+++ b/mercurial/dirstate.py	Mon Apr 06 17:16:55 2015 -0500
@@ -842,9 +842,16 @@
                 audit_path = pathutil.pathauditor(self._root)
 
                 for nf in iter(visit):
+                    # If a stat for the same file was already added with a
+                    # different case, don't add one for this, since that would
+                    # make it appear as if the file exists under both names
+                    # on disk.
+                    if (normalizefile and
+                        normalizefile(nf, True, True) in results):
+                        results[nf] = None
                     # Report ignored items in the dmap as long as they are not
                     # under a symlink directory.
-                    if audit_path.check(nf):
+                    elif audit_path.check(nf):
                         try:
                             results[nf] = lstat(join(nf))
                             # file was just ignored, no links, and exists