1
mirror of https://github.com/rclone/rclone synced 2024-11-17 17:30:37 +01:00
rclone/cmd/rmdirs/rmdirs.go

47 lines
1.3 KiB
Go
Raw Normal View History

2016-11-27 19:36:13 +01:00
package rmdir
import (
"context"
"github.com/rclone/rclone/cmd"
"github.com/rclone/rclone/fs/operations"
2016-11-27 19:36:13 +01:00
"github.com/spf13/cobra"
)
var (
leaveRoot = false
)
2016-11-27 19:36:13 +01:00
func init() {
cmd.Root.AddCommand(rmdirsCmd)
rmdirsCmd.Flags().BoolVarP(&leaveRoot, "leave-root", "", leaveRoot, "Do not remove root directory if empty")
2016-11-27 19:36:13 +01:00
}
var rmdirsCmd = &cobra.Command{
Use: "rmdirs remote:path",
Short: `Remove empty directories under the path.`,
Long: `
This recursively removes any empty directories (including directories
that only contain empty directories), that it finds under the path.
The root path itself will also be removed if it is empty, unless
you supply the ` + "`--leave-root`" + ` flag.
2016-11-27 19:36:13 +01:00
Use command ` + "`rmdir`" + ` to delete just the empty directory
given by path, not recurse.
2016-11-27 19:36:13 +01:00
This is useful for tidying up remotes that rclone has left a lot of
empty directories in. For example the ` + "`delete`" + ` command will
delete files but leave the directory structure (unless used with
option ` + "`--rmdirs`" + `).
2016-11-27 19:36:13 +01:00
To delete a path and any objects in it, use ` + "`purge`" + ` command.
2016-11-27 19:36:13 +01:00
`,
Run: func(command *cobra.Command, args []string) {
cmd.CheckArgs(1, 1, command, args)
fdst := cmd.NewFsDir(args)
cmd.Run(true, false, command, func() error {
return operations.Rmdirs(context.Background(), fdst, "", leaveRoot)
2016-11-27 19:36:13 +01:00
})
},
}