mirror of
https://github.com/rclone/rclone
synced 2024-12-10 22:33:56 +01:00
drive: when initialized with a filepath, optional features used incorrect root path – see #2182
This commit is contained in:
parent
1ba3ffdc59
commit
4d553ef701
@ -34,7 +34,7 @@ import (
|
|||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
"golang.org/x/oauth2"
|
"golang.org/x/oauth2"
|
||||||
"golang.org/x/oauth2/google"
|
"golang.org/x/oauth2/google"
|
||||||
"google.golang.org/api/drive/v3"
|
drive "google.golang.org/api/drive/v3"
|
||||||
"google.golang.org/api/googleapi"
|
"google.golang.org/api/googleapi"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -551,24 +551,28 @@ func NewFs(name, path string) (fs.Fs, error) {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
// Assume it is a file
|
// Assume it is a file
|
||||||
newRoot, remote := dircache.SplitPath(root)
|
newRoot, remote := dircache.SplitPath(root)
|
||||||
newF := *f
|
tempF := *f
|
||||||
newF.dirCache = dircache.New(newRoot, f.rootFolderID, &newF)
|
tempF.dirCache = dircache.New(newRoot, f.rootFolderID, &tempF)
|
||||||
newF.root = newRoot
|
tempF.root = newRoot
|
||||||
// Make new Fs which is the parent
|
// Make new Fs which is the parent
|
||||||
err = newF.dirCache.FindRoot(false)
|
err = tempF.dirCache.FindRoot(false)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// No root so return old f
|
// No root so return old f
|
||||||
return f, nil
|
return f, nil
|
||||||
}
|
}
|
||||||
entries, err := newF.List("")
|
entries, err := tempF.List("")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
// unable to list folder so return old f
|
// unable to list folder so return old f
|
||||||
return f, nil
|
return f, nil
|
||||||
}
|
}
|
||||||
for _, e := range entries {
|
for _, e := range entries {
|
||||||
if _, isObject := e.(fs.Object); isObject && e.Remote() == remote {
|
if _, isObject := e.(fs.Object); isObject && e.Remote() == remote {
|
||||||
// return an error with an fs which points to the parent
|
// XXX: update the old f here instead of returning tempF, since
|
||||||
return &newF, fs.ErrorIsFile
|
// `features` were already filled with functions having *f as a receiver.
|
||||||
|
// See https://github.com/ncw/rclone/issues/2182
|
||||||
|
f.dirCache = tempF.dirCache
|
||||||
|
f.root = tempF.root
|
||||||
|
return f, fs.ErrorIsFile
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// File doesn't exist so return old f
|
// File doesn't exist so return old f
|
||||||
|
Loading…
Reference in New Issue
Block a user