Traverse paths in the same order as parent snapshot
This is the 2nd partial fix to #513. The archivepipe requires the snapshot paths and the backup paths to be traversed in the same order, and they were sorted differently: the backup paths by full path, and the snapshot by basename path.
This commit is contained in:
parent
7572586ded
commit
4ea62ecbcc
1 changed files with 10 additions and 1 deletions
|
@ -622,12 +622,21 @@ func unique(items []string) []string {
|
||||||
return items
|
return items
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Snapshots have contents sorted by basename, but we receive full paths.
|
||||||
|
// For the archivePipe to advance them in pairs, we traverse the given
|
||||||
|
// paths in the same order as the snapshot.
|
||||||
|
type BaseNameSlice []string
|
||||||
|
|
||||||
|
func (p BaseNameSlice) Len() int { return len(p) }
|
||||||
|
func (p BaseNameSlice) Less(i, j int) bool { return filepath.Base(p[i]) < filepath.Base(p[j]) }
|
||||||
|
func (p BaseNameSlice) Swap(i, j int) { p[i], p[j] = p[j], p[i] }
|
||||||
|
|
||||||
// Snapshot creates a snapshot of the given paths. If parentID is set, this is
|
// Snapshot creates a snapshot of the given paths. If parentID is set, this is
|
||||||
// used to compare the files to the ones archived at the time this snapshot was
|
// used to compare the files to the ones archived at the time this snapshot was
|
||||||
// taken.
|
// taken.
|
||||||
func (arch *Archiver) Snapshot(p *Progress, paths []string, parentID *backend.ID) (*Snapshot, backend.ID, error) {
|
func (arch *Archiver) Snapshot(p *Progress, paths []string, parentID *backend.ID) (*Snapshot, backend.ID, error) {
|
||||||
paths = unique(paths)
|
paths = unique(paths)
|
||||||
sort.Strings(paths)
|
sort.Sort(BaseNameSlice(paths))
|
||||||
|
|
||||||
debug.Log("Archiver.Snapshot", "start for %v", paths)
|
debug.Log("Archiver.Snapshot", "start for %v", paths)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue