forked from TrueCloudLab/restic
Merge pull request #1712 from restic/list-ignore-non-existing-dirs
Improve handling non-existing dirs in List()
This commit is contained in:
commit
2c76e724ab
2 changed files with 12 additions and 1 deletions
|
@ -235,7 +235,7 @@ func (b *Local) List(ctx context.Context, t restic.FileType, fn func(restic.File
|
||||||
debug.Log("List %v", t)
|
debug.Log("List %v", t)
|
||||||
|
|
||||||
basedir, subdirs := b.Basedir(t)
|
basedir, subdirs := b.Basedir(t)
|
||||||
return fs.Walk(basedir, func(path string, fi os.FileInfo, err error) error {
|
err := fs.Walk(basedir, func(path string, fi os.FileInfo, err error) error {
|
||||||
debug.Log("walk on %v\n", path)
|
debug.Log("walk on %v\n", path)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
@ -271,6 +271,13 @@ func (b *Local) List(ctx context.Context, t restic.FileType, fn func(restic.File
|
||||||
|
|
||||||
return ctx.Err()
|
return ctx.Err()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if b.IsNotExist(err) {
|
||||||
|
debug.Log("ignoring non-existing directory")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete removes the repository and all files.
|
// Delete removes the repository and all files.
|
||||||
|
|
|
@ -425,6 +425,10 @@ func (r *SFTP) List(ctx context.Context, t restic.FileType, fn func(restic.FileI
|
||||||
walker := r.c.Walk(basedir)
|
walker := r.c.Walk(basedir)
|
||||||
for walker.Step() {
|
for walker.Step() {
|
||||||
if walker.Err() != nil {
|
if walker.Err() != nil {
|
||||||
|
if r.IsNotExist(walker.Err()) {
|
||||||
|
debug.Log("ignoring non-existing directory")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
return walker.Err()
|
return walker.Err()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue