forked from TrueCloudLab/rclone
bbf9b1b3d2
Before this change, bisync supported `--backup-dir` only when `Path1` and `Path2` were different paths on the same remote. With this change, bisync introduces new `--backup-dir1` and `--backup-dir2` flags to support separate backup-dirs for `Path1` and `Path2`. `--backup-dir1` and `--backup-dir2` can use different remotes from each other, but `--backup-dir1` must use the same remote as `Path1`, and `--backup-dir2` must use the same remote as `Path2`. Each backup directory must not overlap its respective bisync Path without being excluded by a filter rule. The standard `--backup-dir` will also work, if both paths use the same remote (but note that deleted files from both paths would be mixed together in the same dir). If either `--backup-dir1` and `--backup-dir2` are set, they will override `--backup-dir`.
60 lines
2.4 KiB
Go
60 lines
2.4 KiB
Go
package bisync
|
|
|
|
import (
|
|
"strconv"
|
|
"strings"
|
|
)
|
|
|
|
func makeHelp(help string) string {
|
|
replacer := strings.NewReplacer(
|
|
"|", "`",
|
|
"{MAXDELETE}", strconv.Itoa(DefaultMaxDelete),
|
|
"{CHECKFILE}", DefaultCheckFilename,
|
|
// "{WORKDIR}", DefaultWorkdir,
|
|
)
|
|
return replacer.Replace(help)
|
|
}
|
|
|
|
var shortHelp = `Perform bidirectional synchronization between two paths.`
|
|
|
|
var rcHelp = makeHelp(`This takes the following parameters
|
|
|
|
- path1 - a remote directory string e.g. |drive:path1|
|
|
- path2 - a remote directory string e.g. |drive:path2|
|
|
- dryRun - dry-run mode
|
|
- resync - performs the resync run
|
|
- checkAccess - abort if {CHECKFILE} files are not found on both filesystems
|
|
- checkFilename - file name for checkAccess (default: {CHECKFILE})
|
|
- maxDelete - abort sync if percentage of deleted files is above
|
|
this threshold (default: {MAXDELETE})
|
|
- force - Bypass maxDelete safety check and run the sync
|
|
- checkSync - |true| by default, |false| disables comparison of final listings,
|
|
|only| will skip sync, only compare listings from the last run
|
|
- createEmptySrcDirs - Sync creation and deletion of empty directories.
|
|
(Not compatible with --remove-empty-dirs)
|
|
- removeEmptyDirs - remove empty directories at the final cleanup step
|
|
- filtersFile - read filtering patterns from a file
|
|
- ignoreListingChecksum - Do not use checksums for listings
|
|
- resilient - Allow future runs to retry after certain less-serious errors, instead of requiring resync.
|
|
Use at your own risk!
|
|
- workdir - server directory for history files (default: |~/.cache/rclone/bisync|)
|
|
- backupdir1 - --backup-dir for Path1. Must be a non-overlapping path on the same remote.
|
|
- backupdir2 - --backup-dir for Path2. Must be a non-overlapping path on the same remote.
|
|
- noCleanup - retain working files
|
|
|
|
See [bisync command help](https://rclone.org/commands/rclone_bisync/)
|
|
and [full bisync description](https://rclone.org/bisync/)
|
|
for more information.`)
|
|
|
|
var longHelp = shortHelp + makeHelp(`
|
|
|
|
[Bisync](https://rclone.org/bisync/) provides a
|
|
bidirectional cloud sync solution in rclone.
|
|
It retains the Path1 and Path2 filesystem listings from the prior run.
|
|
On each successive run it will:
|
|
- list files on Path1 and Path2, and check for changes on each side.
|
|
Changes include |New|, |Newer|, |Older|, and |Deleted| files.
|
|
- Propagate changes on Path1 to Path2, and vice-versa.
|
|
|
|
See [full bisync description](https://rclone.org/bisync/) for details.
|
|
`)
|