aboutsummaryrefslogtreecommitdiff
path: root/cmd/podman/rm.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2019-02-08 20:12:38 +0100
committerGitHub <noreply@github.com>2019-02-08 20:12:38 +0100
commitafd4d5f4a4b05f421e6f336b4d74a0d808be57ed (patch)
tree2ccb4a0bd9bda70c1c258dcb1b8aca8961d9ad30 /cmd/podman/rm.go
parent962850c6e0dfcee926af31fc0ad24f1f6c26f8ac (diff)
parent25a3923b61a5ca014318e6d957f68abd03947297 (diff)
downloadpodman-afd4d5f4a4b05f421e6f336b4d74a0d808be57ed.tar.gz
podman-afd4d5f4a4b05f421e6f336b4d74a0d808be57ed.tar.bz2
podman-afd4d5f4a4b05f421e6f336b4d74a0d808be57ed.zip
Merge pull request #2274 from baude/cobraprep
Migrate to cobra CLI
Diffstat (limited to 'cmd/podman/rm.go')
-rw-r--r--cmd/podman/rm.go65
1 files changed, 31 insertions, 34 deletions
diff --git a/cmd/podman/rm.go b/cmd/podman/rm.go
index 7c0569b78..bb9a913c9 100644
--- a/cmd/podman/rm.go
+++ b/cmd/podman/rm.go
@@ -2,67 +2,64 @@ package main
import (
"fmt"
+
+ "github.com/containers/libpod/cmd/podman/cliconfig"
"github.com/containers/libpod/cmd/podman/libpodruntime"
"github.com/containers/libpod/cmd/podman/shared"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
- "github.com/urfave/cli"
+ "github.com/spf13/cobra"
)
var (
- rmFlags = []cli.Flag{
- cli.BoolFlag{
- Name: "all, a",
- Usage: "Remove all containers",
- },
- cli.BoolFlag{
- Name: "force, f",
- Usage: "Force removal of a running container. The default is false",
- },
- LatestFlag,
- cli.BoolFlag{
- Name: "volumes, v",
- Usage: "Remove the volumes associated with the container (Not implemented yet)",
- },
- }
+ rmCommand cliconfig.RmValues
rmDescription = fmt.Sprintf(`
Podman rm will remove one or more containers from the host.
The container name or ID can be used. This does not remove images.
Running containers will not be removed without the -f option.
`)
- rmCommand = cli.Command{
- Name: "rm",
- Usage: "Remove one or more containers",
- Description: rmDescription,
- Flags: sortFlags(rmFlags),
- Action: rmCmd,
- ArgsUsage: "",
- UseShortOptionHandling: true,
- OnUsageError: usageErrorHandler,
+ _rmCommand = &cobra.Command{
+ Use: "rm",
+ Short: "Remove one or more containers",
+ Long: rmDescription,
+ RunE: func(cmd *cobra.Command, args []string) error {
+ rmCommand.InputArgs = args
+ rmCommand.GlobalFlags = MainGlobalOpts
+ return rmCmd(&rmCommand)
+ },
+ Example: "",
}
)
+func init() {
+ rmCommand.Command = _rmCommand
+ flags := rmCommand.Flags()
+ flags.BoolVarP(&rmCommand.All, "all", "a", false, "Remove all containers")
+ flags.BoolVarP(&rmCommand.Force, "force", "f", false, "Force removal of a running container. The default is false")
+ flags.BoolVarP(&rmCommand.Latest, "latest", "l", false, "Act on the latest container podman is aware of")
+ flags.BoolVarP(&rmCommand.Volumes, "volumes", "v", false, "Remove the volumes associated with the container (Not implemented yet)")
+
+ rootCmd.AddCommand(rmCommand.Command)
+}
+
// saveCmd saves the image to either docker-archive or oci
-func rmCmd(c *cli.Context) error {
+func rmCmd(c *cliconfig.RmValues) error {
var (
deleteFuncs []shared.ParallelWorkerInput
)
ctx := getContext()
- if err := validateFlags(c, rmFlags); err != nil {
- return err
- }
- runtime, err := libpodruntime.GetRuntime(c)
+ runtime, err := libpodruntime.GetRuntime(&c.PodmanCommand)
if err != nil {
return errors.Wrapf(err, "could not get runtime")
}
defer runtime.Shutdown(false)
- if err := checkAllAndLatest(c); err != nil {
+ if err := checkAllAndLatest(&c.PodmanCommand); err != nil {
return err
}
- delContainers, err := getAllOrLatestContainers(c, runtime, -1, "all")
+ delContainers, err := getAllOrLatestContainers(&c.PodmanCommand, runtime, -1, "all")
if err != nil {
if len(delContainers) == 0 {
return err
@@ -73,7 +70,7 @@ func rmCmd(c *cli.Context) error {
for _, container := range delContainers {
con := container
f := func() error {
- return runtime.RemoveContainer(ctx, con, c.Bool("force"))
+ return runtime.RemoveContainer(ctx, con, c.Force)
}
deleteFuncs = append(deleteFuncs, shared.ParallelWorkerInput{
@@ -83,7 +80,7 @@ func rmCmd(c *cli.Context) error {
}
maxWorkers := shared.Parallelize("rm")
if c.GlobalIsSet("max-workers") {
- maxWorkers = c.GlobalInt("max-workers")
+ maxWorkers = c.GlobalFlags.MaxWorks
}
logrus.Debugf("Setting maximum workers to %d", maxWorkers)