Merge pull request #134 from justincormack/hardlink-path

Fix hardlinks in tar output
This commit is contained in:
Justin Cormack 2017-08-02 11:34:47 +01:00 committed by GitHub
commit 305ad031e8
2 changed files with 15 additions and 1 deletions

View File

@ -7,6 +7,7 @@ import (
"errors"
"io"
"io/ioutil"
"path/filepath"
"github.com/moby/tool/src/pad4"
"github.com/surma/gocpio"
@ -27,8 +28,17 @@ func typeconv(thdr *tar.Header) int64 {
case tar.TypeRegA:
return cpio.TYPE_REG
// Currently hard links not supported very well :)
// Convert to relative symlink as absolute will not work in container
// cpio does support hardlinks but file contents still duplicated, so rely
// on compression to fix that which is fairly ugly. Symlink has not caused issues.
case tar.TypeLink:
thdr.Linkname = "/" + thdr.Linkname
dir := filepath.Dir(thdr.Name)
rel, err := filepath.Rel(dir, thdr.Linkname)
if err != nil {
// should never happen, but leave as full abs path
rel = "/" + thdr.Linkname
}
thdr.Linkname = rel
return cpio.TYPE_SYMLINK
case tar.TypeSymlink:
return cpio.TYPE_SYMLINK

View File

@ -172,6 +172,10 @@ func ImageTar(image, prefix string, tw tarWriter, trust bool, pull bool, resolv
} else {
log.Debugf("image tar: %s %s add %s", image, prefix, hdr.Name)
hdr.Name = prefix + hdr.Name
if hdr.Typeflag == tar.TypeLink {
// hard links are referenced by full path so need to be adjusted
hdr.Linkname = prefix + hdr.Linkname
}
if err := tw.WriteHeader(hdr); err != nil {
return err
}