drive: when initialized with a filepath, optional features used incorrect root path – see #2182

This commit is contained in:
Stefan Breunig 2018-03-28 20:33:39 +02:00
parent 1ba3ffdc59
commit 4d553ef701

View File

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