Prune named but untagged images if danglingOnly=true

Signed-off-by: Kenfe-Mickael Laventure <mickael.laventure@gmail.com>
This commit is contained in:
Kenfe-Mickael Laventure 2017-01-20 13:42:55 -08:00
parent a3dff7c3db
commit 044fa10309
1 changed files with 20 additions and 15 deletions

View File

@ -135,24 +135,29 @@ func (daemon *Daemon) ImagesPrune(pruneFilters filters.Args) (*types.ImagesPrune
deletedImages := []types.ImageDelete{} deletedImages := []types.ImageDelete{}
refs := daemon.referenceStore.References(dgst) refs := daemon.referenceStore.References(dgst)
if len(refs) > 0 { if len(refs) > 0 {
if danglingOnly { shouldDelete := !danglingOnly
// Not a dangling image if !shouldDelete {
continue hasTag := false
for _, ref := range refs {
if _, ok := ref.(reference.NamedTagged); ok {
hasTag = true
break
}
}
// Only delete if it's untagged (i.e. repo:<none>)
shouldDelete = !hasTag
} }
nrRefs := len(refs) if shouldDelete {
for _, ref := range refs { for _, ref := range refs {
// If nrRefs == 1, we have an image marked as myreponame:<none> imgDel, err := daemon.ImageDelete(ref.String(), false, true)
// i.e. the tag content was changed if err != nil {
if _, ok := ref.(reference.Canonical); ok && nrRefs > 1 { logrus.Warnf("could not delete reference %s: %v", ref.String(), err)
continue continue
}
deletedImages = append(deletedImages, imgDel...)
} }
imgDel, err := daemon.ImageDelete(ref.String(), false, true)
if err != nil {
logrus.Warnf("could not delete reference %s: %v", ref.String(), err)
continue
}
deletedImages = append(deletedImages, imgDel...)
} }
} else { } else {
imgDel, err := daemon.ImageDelete(hex, false, true) imgDel, err := daemon.ImageDelete(hex, false, true)