summaryrefslogtreecommitdiff
path: root/cmd/podman/containers_prune.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2020-04-16 14:04:58 -0700
committerGitHub <noreply@github.com>2020-04-16 14:04:58 -0700
commit0d2b5532c417c58bd24e71a56c5c55b43e423a59 (patch)
tree4001e8e47a022bb1b9bfbf2332c42e1aeb802f9e /cmd/podman/containers_prune.go
parent88c6fd06cd54fb9a8826306dfdf1a77e400de5de (diff)
parent241326a9a8c20ad7f2bcf651416b836e7778e090 (diff)
downloadpodman-0d2b5532c417c58bd24e71a56c5c55b43e423a59.tar.gz
podman-0d2b5532c417c58bd24e71a56c5c55b43e423a59.tar.bz2
podman-0d2b5532c417c58bd24e71a56c5c55b43e423a59.zip
Merge pull request #5852 from baude/v1prune
Podman V2 birth
Diffstat (limited to 'cmd/podman/containers_prune.go')
-rw-r--r--cmd/podman/containers_prune.go86
1 files changed, 0 insertions, 86 deletions
diff --git a/cmd/podman/containers_prune.go b/cmd/podman/containers_prune.go
deleted file mode 100644
index 3953a489d..000000000
--- a/cmd/podman/containers_prune.go
+++ /dev/null
@@ -1,86 +0,0 @@
-package main
-
-import (
- "bufio"
- "fmt"
- "os"
- "strings"
-
- "github.com/containers/libpod/cmd/podman/cliconfig"
- "github.com/containers/libpod/cmd/podman/shared"
- "github.com/containers/libpod/libpod/define"
- "github.com/containers/libpod/pkg/adapter"
- "github.com/pkg/errors"
- "github.com/spf13/cobra"
-)
-
-var (
- pruneContainersCommand cliconfig.PruneContainersValues
- pruneContainersDescription = `
- podman container prune
-
- Removes all stopped | exited containers
-`
- _pruneContainersCommand = &cobra.Command{
- Use: "prune",
- Args: noSubArgs,
- Short: "Remove all stopped | exited containers",
- Long: pruneContainersDescription,
- RunE: func(cmd *cobra.Command, args []string) error {
- pruneContainersCommand.InputArgs = args
- pruneContainersCommand.GlobalFlags = MainGlobalOpts
- pruneContainersCommand.Remote = remoteclient
- return pruneContainersCmd(&pruneContainersCommand)
- },
- }
-)
-
-func init() {
- pruneContainersCommand.Command = _pruneContainersCommand
- pruneContainersCommand.SetHelpTemplate(HelpTemplate())
- pruneContainersCommand.SetUsageTemplate(UsageTemplate())
- flags := pruneContainersCommand.Flags()
- flags.BoolVarP(&pruneContainersCommand.Force, "force", "f", false, "Skip interactive prompt for container removal")
- flags.StringArrayVar(&pruneContainersCommand.Filter, "filter", []string{}, "Provide filter values (e.g. 'until=<timestamp>')")
-}
-
-func pruneContainersCmd(c *cliconfig.PruneContainersValues) error {
- if !c.Force {
- reader := bufio.NewReader(os.Stdin)
- fmt.Printf(`WARNING! This will remove all stopped containers.
-Are you sure you want to continue? [y/N] `)
- answer, err := reader.ReadString('\n')
- if err != nil {
- return errors.Wrapf(err, "error reading input")
- }
- if strings.ToLower(answer)[0] != 'y' {
- return nil
- }
- }
-
- runtime, err := adapter.GetRuntime(getContext(), &c.PodmanCommand)
- if err != nil {
- return errors.Wrapf(err, "could not get runtime")
- }
- defer runtime.DeferredShutdown(false)
-
- maxWorkers := shared.DefaultPoolSize("prune")
- if c.GlobalIsSet("max-workers") {
- maxWorkers = c.GlobalFlags.MaxWorks
- }
- ok, failures, err := runtime.Prune(getContext(), maxWorkers, c.Filter)
- if err != nil {
- if errors.Cause(err) == define.ErrNoSuchCtr {
- if len(c.InputArgs) > 1 {
- exitCode = define.ExecErrorCodeGeneric
- } else {
- exitCode = 1
- }
- }
- return err
- }
- if len(failures) > 0 {
- exitCode = define.ExecErrorCodeGeneric
- }
- return printCmdResults(ok, failures)
-}