summaryrefslogtreecommitdiff
path: root/cmd/podman/errors.go
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2019-02-23 22:10:03 +0100
committerGitHub <noreply@github.com>2019-02-23 22:10:03 +0100
commit3825db5aee1afee1dfd06ad9e29f216110396d6f (patch)
treee5af3145b1506aead8539f37eae994c2fed785e1 /cmd/podman/errors.go
parent0969d725a3b302d9baa0616a204f7fc824404973 (diff)
parent6208d534645648ccee0e136b0e659cee1c26ab78 (diff)
downloadpodman-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.go41
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())
+ }
+}