2022-08-28 19:21:57 +08:00
|
|
|
// Package purge provides the purge command.
|
2016-08-06 00:12:27 +08:00
|
|
|
package purge
|
|
|
|
|
|
|
|
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"
|
2016-08-06 00:12:27 +08:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2019-10-11 23:58:11 +08:00
|
|
|
cmd.Root.AddCommand(commandDefinition)
|
2016-08-06 00:12:27 +08:00
|
|
|
}
|
|
|
|
|
2019-10-11 23:58:11 +08:00
|
|
|
var commandDefinition = &cobra.Command{
|
2016-08-06 00:12:27 +08:00
|
|
|
Use: "purge remote:path",
|
|
|
|
Short: `Remove the path and all of its contents.`,
|
2024-08-13 00:17:46 +08:00
|
|
|
Long: `Remove the path and all of its contents. Note that this does not obey
|
2022-06-19 21:51:37 +08:00
|
|
|
include/exclude filters - everything will be removed. Use the
|
|
|
|
[delete](/commands/rclone_delete/) command if you want to selectively
|
|
|
|
delete files. To delete empty directories only, use command
|
|
|
|
[rmdir](/commands/rclone_rmdir/) or [rmdirs](/commands/rclone_rmdirs/).
|
2020-06-06 00:04:23 +08:00
|
|
|
|
|
|
|
**Important**: Since this can cause data loss, test first with the
|
|
|
|
` + "`--dry-run` or the `--interactive`/`-i`" + ` flag.
|
2016-08-06 00:12:27 +08:00
|
|
|
`,
|
2023-07-11 01:34:10 +08:00
|
|
|
Annotations: map[string]string{
|
|
|
|
"groups": "Important",
|
|
|
|
},
|
2016-08-06 00:12:27 +08:00
|
|
|
Run: func(command *cobra.Command, args []string) {
|
|
|
|
cmd.CheckArgs(1, 1, command, args)
|
2018-05-08 00:58:16 +08:00
|
|
|
fdst := cmd.NewFsDir(args)
|
2016-12-05 00:52:24 +08:00
|
|
|
cmd.Run(true, false, command, func() error {
|
2019-06-17 16:34:30 +08:00
|
|
|
return operations.Purge(context.Background(), fdst, "")
|
2016-08-06 00:12:27 +08:00
|
|
|
})
|
|
|
|
},
|
|
|
|
}
|