2016-08-05 16:12:27 +00:00
|
|
|
package copy
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/ncw/rclone/cmd"
|
|
|
|
"github.com/ncw/rclone/fs"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2016-10-22 11:05:45 +00:00
|
|
|
cmd.Root.AddCommand(commandDefintion)
|
2016-08-05 16:12:27 +00:00
|
|
|
}
|
|
|
|
|
2016-10-22 11:05:45 +00:00
|
|
|
var commandDefintion = &cobra.Command{
|
2016-08-05 16:12:27 +00:00
|
|
|
Use: "copy source:path dest:path",
|
|
|
|
Short: `Copy files from source to dest, skipping already copied`,
|
|
|
|
Long: `
|
|
|
|
Copy the source to the destination. Doesn't transfer
|
|
|
|
unchanged files, testing by size and modification time or
|
|
|
|
MD5SUM. Doesn't delete files from the destination.
|
|
|
|
|
|
|
|
Note that it is always the contents of the directory that is synced,
|
|
|
|
not the directory so when source:path is a directory, it's the
|
|
|
|
contents of source:path that are copied, not the directory name and
|
|
|
|
contents.
|
|
|
|
|
|
|
|
If dest:path doesn't exist, it is created and the source:path contents
|
|
|
|
go there.
|
|
|
|
|
|
|
|
For example
|
|
|
|
|
|
|
|
rclone copy source:sourcepath dest:destpath
|
|
|
|
|
|
|
|
Let's say there are two files in sourcepath
|
|
|
|
|
|
|
|
sourcepath/one.txt
|
|
|
|
sourcepath/two.txt
|
|
|
|
|
|
|
|
This copies them to
|
|
|
|
|
|
|
|
destpath/one.txt
|
|
|
|
destpath/two.txt
|
|
|
|
|
|
|
|
Not to
|
|
|
|
|
|
|
|
destpath/sourcepath/one.txt
|
|
|
|
destpath/sourcepath/two.txt
|
|
|
|
|
2016-10-23 16:34:17 +00:00
|
|
|
If you are familiar with ` + "`rsync`" + `, rclone always works as if you had
|
2016-08-05 16:12:27 +00:00
|
|
|
written a trailing / - meaning "copy the contents of this directory".
|
|
|
|
This applies to all commands and whether you are talking about the
|
|
|
|
source or destination.
|
|
|
|
|
2016-10-23 16:34:17 +00:00
|
|
|
See the ` + "`--no-traverse`" + ` option for controlling whether rclone lists
|
2016-08-05 16:12:27 +00:00
|
|
|
the destination directory or not.
|
|
|
|
`,
|
|
|
|
Run: func(command *cobra.Command, args []string) {
|
|
|
|
cmd.CheckArgs(2, 2, command, args)
|
|
|
|
fsrc, fdst := cmd.NewFsSrcDst(args)
|
|
|
|
cmd.Run(true, command, func() error {
|
|
|
|
return fs.CopyDir(fdst, fsrc)
|
|
|
|
})
|
|
|
|
},
|
|
|
|
}
|