diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2019-02-23 22:10:03 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-02-23 22:10:03 +0100 |
commit | 3825db5aee1afee1dfd06ad9e29f216110396d6f (patch) | |
tree | e5af3145b1506aead8539f37eae994c2fed785e1 /cmd/podman/errors.go | |
parent | 0969d725a3b302d9baa0616a204f7fc824404973 (diff) | |
parent | 6208d534645648ccee0e136b0e659cee1c26ab78 (diff) | |
download | podman-3825db5aee1afee1dfd06ad9e29f216110396d6f.tar.gz podman-3825db5aee1afee1dfd06ad9e29f216110396d6f.tar.bz2 podman-3825db5aee1afee1dfd06ad9e29f216110396d6f.zip |
Merge pull request #2404 from baude/remoteerrors
make remote-client error messaging more robust
Diffstat (limited to 'cmd/podman/errors.go')
-rw-r--r-- | cmd/podman/errors.go | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/cmd/podman/errors.go b/cmd/podman/errors.go new file mode 100644 index 000000000..192f97049 --- /dev/null +++ b/cmd/podman/errors.go @@ -0,0 +1,41 @@ +package main + +import ( + "fmt" + "os" + "os/exec" + "syscall" + + "github.com/containers/libpod/cmd/podman/varlink" + "github.com/pkg/errors" + "github.com/sirupsen/logrus" +) + +func outputError(err error) { + if MainGlobalOpts.LogLevel == "debug" { + logrus.Errorf(err.Error()) + } else { + if ee, ok := err.(*exec.ExitError); ok { + if status, ok := ee.Sys().(syscall.WaitStatus); ok { + exitCode = status.ExitStatus() + } + } + var ne error + switch e := err.(type) { + // For some reason golang wont let me list them with commas so listing them all. + case *iopodman.ImageNotFound: + ne = errors.New(e.Reason) + case *iopodman.ContainerNotFound: + ne = errors.New(e.Reason) + case *iopodman.PodNotFound: + ne = errors.New(e.Reason) + case *iopodman.VolumeNotFound: + ne = errors.New(e.Reason) + case *iopodman.ErrorOccurred: + ne = errors.New(e.Reason) + default: + ne = err + } + fmt.Fprintln(os.Stderr, "Error:", ne.Error()) + } +} |