mirror of
https://github.com/rclone/rclone.git
synced 2025-01-11 00:40:03 +01:00
drive: fix duplication of Google docs on server side copy #4517
Before this change, rclone was looking for the file without the extension to see if it existed which meant that it never did. This change checks the destination file exists firsts, before removing the extension.
This commit is contained in:
parent
b5ba077a2f
commit
2bcc66c805
@ -2272,6 +2272,12 @@ func (f *Fs) Copy(ctx context.Context, src fs.Object, remote string) (fs.Object,
|
|||||||
return nil, fs.ErrorCantCopy
|
return nil, fs.ErrorCantCopy
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Look to see if there is an existing object before we remove
|
||||||
|
// the extension from the remote
|
||||||
|
existingObject, _ := f.NewObject(ctx, remote)
|
||||||
|
|
||||||
|
// Adjust the remote name to be without the extension if we
|
||||||
|
// are about to create a doc.
|
||||||
if ext != "" {
|
if ext != "" {
|
||||||
if !strings.HasSuffix(remote, ext) {
|
if !strings.HasSuffix(remote, ext) {
|
||||||
fs.Debugf(src, "Can't copy - not same document type")
|
fs.Debugf(src, "Can't copy - not same document type")
|
||||||
@ -2280,9 +2286,6 @@ func (f *Fs) Copy(ctx context.Context, src fs.Object, remote string) (fs.Object,
|
|||||||
remote = remote[:len(remote)-len(ext)]
|
remote = remote[:len(remote)-len(ext)]
|
||||||
}
|
}
|
||||||
|
|
||||||
// Look to see if there is an existing object
|
|
||||||
existingObject, _ := f.NewObject(ctx, remote)
|
|
||||||
|
|
||||||
createInfo, err := f.createFileInfo(ctx, remote, src.ModTime(ctx))
|
createInfo, err := f.createFileInfo(ctx, remote, src.ModTime(ctx))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -2329,7 +2332,7 @@ func (f *Fs) Copy(ctx context.Context, src fs.Object, remote string) (fs.Object,
|
|||||||
// change effective, without it is is ignored. This is
|
// change effective, without it is is ignored. This is
|
||||||
// probably some eventual consistency nastiness.
|
// probably some eventual consistency nastiness.
|
||||||
sleepTime := 2 * time.Second
|
sleepTime := 2 * time.Second
|
||||||
fs.Debugf(f, "Sleeping for %v before setting the modtime to work around drive bug - see #4517")
|
fs.Debugf(f, "Sleeping for %v before setting the modtime to work around drive bug - see #4517", sleepTime)
|
||||||
time.Sleep(sleepTime)
|
time.Sleep(sleepTime)
|
||||||
err = newObject.SetModTime(ctx, src.ModTime(ctx))
|
err = newObject.SetModTime(ctx, src.ModTime(ctx))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
Loading…
Reference in New Issue
Block a user