]> arthur.barton.de Git - bup.git/blobdiff - cmd/save-cmd.py
save: don't confuse metadata on duplicate files
[bup.git] / cmd / save-cmd.py
index 36cd43a009335f8a62f4cbb6998bda037fa66024..43f41e7477ad4a609f32efd9b079a32c1c643b8a 100755 (executable)
@@ -158,15 +158,20 @@ def _pop(force_tree, dir_metadata=None):
     else:
         names_seen = set()
         clean_list = []
+        metaidx = 1 # entry at 0 is for the dir
         for x in shalist:
             name = x[1]
             if name in names_seen:
                 parent_path = '/'.join(parts) + '/'
                 add_error('error: ignoring duplicate path %r in %r'
                           % (name, parent_path))
+                if not stat.S_ISDIR(x[0]):
+                    del metalist[metaidx]
             else:
                 names_seen.add(name)
                 clean_list.append(x)
+                if not stat.S_ISDIR(x[0]):
+                    metaidx += 1
         tree = w.new_tree(clean_list)
     if shalists:
         shalists[-1].append((GIT_MODE_TREE,