Merge pull request #1712 from restic/list-ignore-non-existing-dirs

Improve handling non-existing dirs in List()
This commit is contained in:
Alexander Neumann 2018-04-10 21:54:00 +02:00
commit 2c76e724ab
2 changed files with 12 additions and 1 deletions

View file

@ -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.

View file

@ -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()
} }