|
@@ -356,29 +356,27 @@ func (srv *Server) CmdPort(stdin io.ReadCloser, stdout io.Writer, args ...string
|
|
|
}
|
|
|
|
|
|
// 'docker rmi NAME' removes all images with the name NAME
|
|
|
-func (srv *Server) CmdRmi(stdin io.ReadCloser, stdout io.Writer, args ...string) error {
|
|
|
+func (srv *Server) CmdRmi(stdin io.ReadCloser, stdout io.Writer, args ...string) (err error) {
|
|
|
cmd := rcli.Subcmd(stdout, "rmimage", "[OPTIONS] IMAGE", "Remove an image")
|
|
|
fl_all := cmd.Bool("a", false, "Use IMAGE as a path and remove ALL images in this path")
|
|
|
- if err := cmd.Parse(args); err != nil {
|
|
|
- cmd.Usage()
|
|
|
- return nil
|
|
|
- }
|
|
|
- if cmd.NArg() < 1 {
|
|
|
+ fl_regexp := cmd.Bool("r", false, "Use IMAGE as a regular expression instead of an exact name")
|
|
|
+ if cmd.Parse(args) != nil || cmd.NArg() < 1 {
|
|
|
cmd.Usage()
|
|
|
return nil
|
|
|
}
|
|
|
for _, name := range cmd.Args() {
|
|
|
- var err error
|
|
|
- if *fl_all {
|
|
|
+ if *fl_regexp {
|
|
|
+ err = srv.images.RemoveRegexp(name)
|
|
|
+ } else if *fl_all {
|
|
|
err = srv.images.RemoveInPath(name)
|
|
|
} else {
|
|
|
- image, err := srv.images.Get(name)
|
|
|
- if err != nil {
|
|
|
- return err
|
|
|
- } else if image == nil {
|
|
|
- return errors.New("No such image: " + name)
|
|
|
+ if image, err1 := srv.images.Find(name); err1 != nil {
|
|
|
+ err = err1
|
|
|
+ } else if err1 == nil && image == nil {
|
|
|
+ err = fmt.Errorf("No such image: %s", name)
|
|
|
+ } else {
|
|
|
+ err = srv.images.Remove(image)
|
|
|
}
|
|
|
- err = srv.images.Remove(image)
|
|
|
}
|
|
|
if err != nil {
|
|
|
return err
|