cache: correctly handle fs.ErrorIsFile in GetFn - fixes #3424

This commit is contained in:
buengese 2019-08-09 23:19:41 +02:00 committed by buengese
parent 873e87fc38
commit 0c1eaf1bcb
1 changed files with 4 additions and 4 deletions

8
fs/cache/cache.go vendored
View File

@ -13,15 +13,15 @@ var (
// GetFn gets a fs.Fs named fsString either from the cache or creates
// it afresh with the create function
func GetFn(fsString string, create func(fsString string) (fs.Fs, error)) (f fs.Fs, err error) {
value, err := c.Get(fsString, func(fsString string) (value interface{}, ok bool, error error) {
f, err := create(fsString)
value, err := c.Get(fsString, func(fsString string) (f interface{}, ok bool, err error) {
f, err = create(fsString)
ok = err == nil || err == fs.ErrorIsFile
return f, ok, err
})
if err != nil {
if err != nil && err != fs.ErrorIsFile {
return nil, err
}
return value.(fs.Fs), nil
return value.(fs.Fs), err
}
// Get gets a fs.Fs named fsString either from the cache or creates it afresh