2016-08-06 00:12:27 +08:00
package sync
import (
2019-06-17 16:34:30 +08:00
"context"
2019-07-29 01:47:38 +08:00
"github.com/rclone/rclone/cmd"
"github.com/rclone/rclone/fs/operations"
"github.com/rclone/rclone/fs/sync"
2016-08-06 00:12:27 +08:00
"github.com/spf13/cobra"
)
2019-03-06 16:43:46 +08:00
var (
createEmptySrcDirs = false
)
2016-08-06 00:12:27 +08:00
func init ( ) {
2016-10-22 19:05:45 +08:00
cmd . Root . AddCommand ( commandDefintion )
2019-03-06 16:43:46 +08:00
commandDefintion . Flags ( ) . BoolVarP ( & createEmptySrcDirs , "create-empty-src-dirs" , "" , createEmptySrcDirs , "Create empty source dirs on destination after sync" )
2016-08-06 00:12:27 +08:00
}
2016-10-22 19:05:45 +08:00
var commandDefintion = & cobra . Command {
2016-08-06 00:12:27 +08:00
Use : "sync source:path dest:path" ,
Short : ` Make source and dest identical, modifying destination only. ` ,
Long : `
Sync the source to the destination , changing the destination
only . Doesn ' t transfer unchanged files , testing by size and
modification time or MD5SUM . Destination is updated to match
source , including deleting files if necessary .
* * Important * * : Since this can cause data loss , test first with the
` + " ` " + `--dry-run` + " ` " + ` flag to see exactly what would be copied and deleted .
Note that files in the destination won ' t be deleted if there were any
errors at any point .
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 . See
extended explanation in the ` + " ` " + `copy` + " ` " + ` command above if unsure .
If dest : path doesn ' t exist , it is created and the source : path contents
go there .
2018-10-21 17:51:41 +08:00
* * Note * * : Use the ` + " ` - P ` " + ` / ` + " ` -- progress ` " + ` flag to view real - time transfer statistics
2016-08-06 00:12:27 +08:00
` ,
Run : func ( command * cobra . Command , args [ ] string ) {
cmd . CheckArgs ( 2 , 2 , command , args )
2019-06-23 11:50:09 +08:00
fsrc , srcFileName , fdst := cmd . NewFsSrcFileDst ( args )
2016-12-05 00:52:24 +08:00
cmd . Run ( true , true , command , func ( ) error {
2019-06-23 11:50:09 +08:00
if srcFileName == "" {
return sync . Sync ( context . Background ( ) , fdst , fsrc , createEmptySrcDirs )
}
return operations . CopyFile ( context . Background ( ) , fdst , fsrc , srcFileName , srcFileName )
2016-08-06 00:12:27 +08:00
} )
} ,
}