mirror of https://github.com/containers/podman.git
Update vendor of containers/storage
Signed-off-by: Daniel J Walsh <dwalsh@redhat.com>
This commit is contained in:
parent
605a29a714
commit
d78212a009
4
go.mod
4
go.mod
|
|
@ -19,7 +19,7 @@ require (
|
||||||
github.com/containers/libhvee v0.5.0
|
github.com/containers/libhvee v0.5.0
|
||||||
github.com/containers/ocicrypt v1.1.9
|
github.com/containers/ocicrypt v1.1.9
|
||||||
github.com/containers/psgo v1.8.0
|
github.com/containers/psgo v1.8.0
|
||||||
github.com/containers/storage v1.51.1-0.20231129190156-7d0a0a320f8a
|
github.com/containers/storage v1.51.1-0.20231205203947-fe005407c7d5
|
||||||
github.com/coreos/go-systemd/v22 v22.5.1-0.20231103132048-7d375ecc2b09
|
github.com/coreos/go-systemd/v22 v22.5.1-0.20231103132048-7d375ecc2b09
|
||||||
github.com/coreos/stream-metadata-go v0.4.3
|
github.com/coreos/stream-metadata-go v0.4.3
|
||||||
github.com/crc-org/vfkit v0.5.0
|
github.com/crc-org/vfkit v0.5.0
|
||||||
|
|
@ -145,7 +145,7 @@ require (
|
||||||
github.com/inconshreveable/mousetrap v1.1.0 // indirect
|
github.com/inconshreveable/mousetrap v1.1.0 // indirect
|
||||||
github.com/jinzhu/copier v0.4.0 // indirect
|
github.com/jinzhu/copier v0.4.0 // indirect
|
||||||
github.com/josharian/intern v1.0.0 // indirect
|
github.com/josharian/intern v1.0.0 // indirect
|
||||||
github.com/klauspost/compress v1.17.3 // indirect
|
github.com/klauspost/compress v1.17.4 // indirect
|
||||||
github.com/klauspost/cpuid/v2 v2.2.5 // indirect
|
github.com/klauspost/cpuid/v2 v2.2.5 // indirect
|
||||||
github.com/klauspost/pgzip v1.2.6 // indirect
|
github.com/klauspost/pgzip v1.2.6 // indirect
|
||||||
github.com/kr/fs v0.1.0 // indirect
|
github.com/kr/fs v0.1.0 // indirect
|
||||||
|
|
|
||||||
8
go.sum
8
go.sum
|
|
@ -278,8 +278,8 @@ github.com/containers/ocicrypt v1.1.9/go.mod h1:dTKx1918d8TDkxXvarscpNVY+lyPakPN
|
||||||
github.com/containers/psgo v1.8.0 h1:2loGekmGAxM9ir5OsXWEfGwFxorMPYnc6gEDsGFQvhY=
|
github.com/containers/psgo v1.8.0 h1:2loGekmGAxM9ir5OsXWEfGwFxorMPYnc6gEDsGFQvhY=
|
||||||
github.com/containers/psgo v1.8.0/go.mod h1:T8ZxnX3Ur4RvnhxFJ7t8xJ1F48RhiZB4rSrOaR/qGHc=
|
github.com/containers/psgo v1.8.0/go.mod h1:T8ZxnX3Ur4RvnhxFJ7t8xJ1F48RhiZB4rSrOaR/qGHc=
|
||||||
github.com/containers/storage v1.43.0/go.mod h1:uZ147thiIFGdVTjMmIw19knttQnUCl3y9zjreHrg11s=
|
github.com/containers/storage v1.43.0/go.mod h1:uZ147thiIFGdVTjMmIw19knttQnUCl3y9zjreHrg11s=
|
||||||
github.com/containers/storage v1.51.1-0.20231129190156-7d0a0a320f8a h1:YuHrRNrIAZ+b1yTzoTdNiAEBNqhBmnakrVxfXcH8SC8=
|
github.com/containers/storage v1.51.1-0.20231205203947-fe005407c7d5 h1:eiCkAt+i9BYRjR7KEKPI3iORCSABhY+spM/w8BkI2lo=
|
||||||
github.com/containers/storage v1.51.1-0.20231129190156-7d0a0a320f8a/go.mod h1:FHXkEBvKRmsTeB1JQIFfXnSyXCp+wVrt172O2ZlSzM4=
|
github.com/containers/storage v1.51.1-0.20231205203947-fe005407c7d5/go.mod h1:pMhG1O3eMGlQKpuEuv7ves+K3BsK8/UJs8ctV5fEaoI=
|
||||||
github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk=
|
github.com/coreos/bbolt v1.3.2/go.mod h1:iRUV2dpdMOn7Bo10OQBFzIJO9kkE559Wcmn+qkEiiKk=
|
||||||
github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE=
|
github.com/coreos/etcd v3.3.10+incompatible/go.mod h1:uF7uidLiAD3TWHmW31ZFd/JWoc32PjwdhPthX9715RE=
|
||||||
github.com/coreos/go-iptables v0.4.5/go.mod h1:/mVI274lEDI2ns62jHCDnCyBF9Iwsmekav8Dbxlm1MU=
|
github.com/coreos/go-iptables v0.4.5/go.mod h1:/mVI274lEDI2ns62jHCDnCyBF9Iwsmekav8Dbxlm1MU=
|
||||||
|
|
@ -699,8 +699,8 @@ github.com/klauspost/compress v1.11.13/go.mod h1:aoV0uJVorq1K+umq18yTdKaF57EivdY
|
||||||
github.com/klauspost/compress v1.13.6/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk=
|
github.com/klauspost/compress v1.13.6/go.mod h1:/3/Vjq9QcHkK5uEr5lBEmyoZ1iFhe47etQ6QUkpK6sk=
|
||||||
github.com/klauspost/compress v1.15.7/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
github.com/klauspost/compress v1.15.7/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
||||||
github.com/klauspost/compress v1.15.9/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
github.com/klauspost/compress v1.15.9/go.mod h1:PhcZ0MbTNciWF3rruxRgKxI5NkcHHrHUDtV4Yw2GlzU=
|
||||||
github.com/klauspost/compress v1.17.3 h1:qkRjuerhUU1EmXLYGkSH6EZL+vPSxIrYjLNAK4slzwA=
|
github.com/klauspost/compress v1.17.4 h1:Ej5ixsIri7BrIjBkRZLTo6ghwrEtHFk7ijlczPW4fZ4=
|
||||||
github.com/klauspost/compress v1.17.3/go.mod h1:/dCuZOvVtNoHsyb+cuJD3itjs3NbnF6KH9zAO4BDxPM=
|
github.com/klauspost/compress v1.17.4/go.mod h1:/dCuZOvVtNoHsyb+cuJD3itjs3NbnF6KH9zAO4BDxPM=
|
||||||
github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
|
github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg=
|
||||||
github.com/klauspost/cpuid/v2 v2.2.5 h1:0E5MSMDEoAulmXNFquVs//DdoomxaoTY1kUhbc/qbZg=
|
github.com/klauspost/cpuid/v2 v2.2.5 h1:0E5MSMDEoAulmXNFquVs//DdoomxaoTY1kUhbc/qbZg=
|
||||||
github.com/klauspost/cpuid/v2 v2.2.5/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
|
github.com/klauspost/cpuid/v2 v2.2.5/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws=
|
||||||
|
|
|
||||||
|
|
@ -73,6 +73,13 @@ type ApplyDiffOpts struct {
|
||||||
ForceMask *os.FileMode
|
ForceMask *os.FileMode
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ApplyDiffWithDifferOpts contains optional arguments for ApplyDiffWithDiffer methods.
|
||||||
|
type ApplyDiffWithDifferOpts struct {
|
||||||
|
ApplyDiffOpts
|
||||||
|
|
||||||
|
Flags map[string]interface{}
|
||||||
|
}
|
||||||
|
|
||||||
// InitFunc initializes the storage driver.
|
// InitFunc initializes the storage driver.
|
||||||
type InitFunc func(homedir string, options Options) (Driver, error)
|
type InitFunc func(homedir string, options Options) (Driver, error)
|
||||||
|
|
||||||
|
|
@ -223,9 +230,9 @@ type DriverWithDiffer interface {
|
||||||
Driver
|
Driver
|
||||||
// ApplyDiffWithDiffer applies the changes using the callback function.
|
// ApplyDiffWithDiffer applies the changes using the callback function.
|
||||||
// If id is empty, then a staging directory is created. The staging directory is guaranteed to be usable with ApplyDiffFromStagingDirectory.
|
// If id is empty, then a staging directory is created. The staging directory is guaranteed to be usable with ApplyDiffFromStagingDirectory.
|
||||||
ApplyDiffWithDiffer(id, parent string, options *ApplyDiffOpts, differ Differ) (output DriverWithDifferOutput, err error)
|
ApplyDiffWithDiffer(id, parent string, options *ApplyDiffWithDifferOpts, differ Differ) (output DriverWithDifferOutput, err error)
|
||||||
// ApplyDiffFromStagingDirectory applies the changes using the specified staging directory.
|
// ApplyDiffFromStagingDirectory applies the changes using the specified staging directory.
|
||||||
ApplyDiffFromStagingDirectory(id, parent, stagingDirectory string, diffOutput *DriverWithDifferOutput, options *ApplyDiffOpts) error
|
ApplyDiffFromStagingDirectory(id, parent, stagingDirectory string, diffOutput *DriverWithDifferOutput, options *ApplyDiffWithDifferOpts) error
|
||||||
// CleanupStagingDirectory cleanups the staging directory. It can be used to cleanup the staging directory on errors
|
// CleanupStagingDirectory cleanups the staging directory. It can be used to cleanup the staging directory on errors
|
||||||
CleanupStagingDirectory(stagingDirectory string) error
|
CleanupStagingDirectory(stagingDirectory string) error
|
||||||
// DifferTarget gets the location where files are stored for the layer.
|
// DifferTarget gets the location where files are stored for the layer.
|
||||||
|
|
|
||||||
|
|
@ -2049,7 +2049,7 @@ func (d *Driver) useComposeFs() bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyDiff applies the changes in the new layer using the specified function
|
// ApplyDiff applies the changes in the new layer using the specified function
|
||||||
func (d *Driver) ApplyDiffWithDiffer(id, parent string, options *graphdriver.ApplyDiffOpts, differ graphdriver.Differ) (output graphdriver.DriverWithDifferOutput, err error) {
|
func (d *Driver) ApplyDiffWithDiffer(id, parent string, options *graphdriver.ApplyDiffWithDifferOpts, differ graphdriver.Differ) (output graphdriver.DriverWithDifferOutput, err error) {
|
||||||
var idMappings *idtools.IDMappings
|
var idMappings *idtools.IDMappings
|
||||||
if options != nil {
|
if options != nil {
|
||||||
idMappings = options.Mappings
|
idMappings = options.Mappings
|
||||||
|
|
@ -2100,7 +2100,7 @@ func (d *Driver) ApplyDiffWithDiffer(id, parent string, options *graphdriver.App
|
||||||
}
|
}
|
||||||
|
|
||||||
// ApplyDiffFromStagingDirectory applies the changes using the specified staging directory.
|
// ApplyDiffFromStagingDirectory applies the changes using the specified staging directory.
|
||||||
func (d *Driver) ApplyDiffFromStagingDirectory(id, parent, stagingDirectory string, diffOutput *graphdriver.DriverWithDifferOutput, options *graphdriver.ApplyDiffOpts) error {
|
func (d *Driver) ApplyDiffFromStagingDirectory(id, parent, stagingDirectory string, diffOutput *graphdriver.DriverWithDifferOutput, options *graphdriver.ApplyDiffWithDifferOpts) error {
|
||||||
if filepath.Dir(stagingDirectory) != d.getStagingDir() {
|
if filepath.Dir(stagingDirectory) != d.getStagingDir() {
|
||||||
return fmt.Errorf("%q is not a staging directory", stagingDirectory)
|
return fmt.Errorf("%q is not a staging directory", stagingDirectory)
|
||||||
}
|
}
|
||||||
|
|
@ -2125,8 +2125,6 @@ func (d *Driver) ApplyDiffFromStagingDirectory(id, parent, stagingDirectory stri
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
diffOutput.UncompressedDigest = diffOutput.TOCDigest
|
|
||||||
|
|
||||||
return os.Rename(stagingDirectory, diffPath)
|
return os.Rename(stagingDirectory, diffPath)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -126,6 +126,13 @@ type Layer struct {
|
||||||
// as a DiffID.
|
// as a DiffID.
|
||||||
UncompressedDigest digest.Digest `json:"diff-digest,omitempty"`
|
UncompressedDigest digest.Digest `json:"diff-digest,omitempty"`
|
||||||
|
|
||||||
|
// TOCDigest represents the digest of the Table of Contents (TOC) of the blob.
|
||||||
|
// This digest is utilized when the UncompressedDigest is not
|
||||||
|
// validated during the partial image pull process, but the
|
||||||
|
// TOC itself is validated.
|
||||||
|
// It serves as an alternative reference under these specific conditions.
|
||||||
|
TOCDigest digest.Digest `json:"toc-digest,omitempty"`
|
||||||
|
|
||||||
// UncompressedSize is the length of the blob that was last passed to
|
// UncompressedSize is the length of the blob that was last passed to
|
||||||
// ApplyDiff() or create(), after we decompressed it. If
|
// ApplyDiff() or create(), after we decompressed it. If
|
||||||
// UncompressedDigest is not set, this should be treated as if it were
|
// UncompressedDigest is not set, this should be treated as if it were
|
||||||
|
|
@ -228,6 +235,10 @@ type roLayerStore interface {
|
||||||
// specified uncompressed digest value recorded for them.
|
// specified uncompressed digest value recorded for them.
|
||||||
LayersByUncompressedDigest(d digest.Digest) ([]Layer, error)
|
LayersByUncompressedDigest(d digest.Digest) ([]Layer, error)
|
||||||
|
|
||||||
|
// LayersByTOCDigest returns a slice of the layers with the
|
||||||
|
// specified uncompressed digest value recorded for them.
|
||||||
|
LayersByTOCDigest(d digest.Digest) ([]Layer, error)
|
||||||
|
|
||||||
// Layers returns a slice of the known layers.
|
// Layers returns a slice of the known layers.
|
||||||
Layers() ([]Layer, error)
|
Layers() ([]Layer, error)
|
||||||
}
|
}
|
||||||
|
|
@ -296,13 +307,13 @@ type rwLayerStore interface {
|
||||||
|
|
||||||
// ApplyDiffWithDiffer applies the changes through the differ callback function.
|
// ApplyDiffWithDiffer applies the changes through the differ callback function.
|
||||||
// If to is the empty string, then a staging directory is created by the driver.
|
// If to is the empty string, then a staging directory is created by the driver.
|
||||||
ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error)
|
ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffWithDifferOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error)
|
||||||
|
|
||||||
// CleanupStagingDirectory cleanups the staging directory. It can be used to cleanup the staging directory on errors
|
// CleanupStagingDirectory cleanups the staging directory. It can be used to cleanup the staging directory on errors
|
||||||
CleanupStagingDirectory(stagingDirectory string) error
|
CleanupStagingDirectory(stagingDirectory string) error
|
||||||
|
|
||||||
// ApplyDiffFromStagingDirectory uses stagingDirectory to create the diff.
|
// ApplyDiffFromStagingDirectory uses stagingDirectory to create the diff.
|
||||||
ApplyDiffFromStagingDirectory(id, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffOpts) error
|
ApplyDiffFromStagingDirectory(id, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffWithDifferOpts) error
|
||||||
|
|
||||||
// DifferTarget gets the location where files are stored for the layer.
|
// DifferTarget gets the location where files are stored for the layer.
|
||||||
DifferTarget(id string) (string, error)
|
DifferTarget(id string) (string, error)
|
||||||
|
|
@ -337,6 +348,7 @@ type layerStore struct {
|
||||||
bymount map[string]*Layer
|
bymount map[string]*Layer
|
||||||
bycompressedsum map[digest.Digest][]string
|
bycompressedsum map[digest.Digest][]string
|
||||||
byuncompressedsum map[digest.Digest][]string
|
byuncompressedsum map[digest.Digest][]string
|
||||||
|
bytocsum map[digest.Digest][]string
|
||||||
layerspathsModified [numLayerLocationIndex]time.Time
|
layerspathsModified [numLayerLocationIndex]time.Time
|
||||||
|
|
||||||
// FIXME: This field is only set when constructing layerStore, but locking rules of the driver
|
// FIXME: This field is only set when constructing layerStore, but locking rules of the driver
|
||||||
|
|
@ -366,6 +378,7 @@ func copyLayer(l *Layer) *Layer {
|
||||||
CompressedSize: l.CompressedSize,
|
CompressedSize: l.CompressedSize,
|
||||||
UncompressedDigest: l.UncompressedDigest,
|
UncompressedDigest: l.UncompressedDigest,
|
||||||
UncompressedSize: l.UncompressedSize,
|
UncompressedSize: l.UncompressedSize,
|
||||||
|
TOCDigest: l.TOCDigest,
|
||||||
CompressionType: l.CompressionType,
|
CompressionType: l.CompressionType,
|
||||||
ReadOnly: l.ReadOnly,
|
ReadOnly: l.ReadOnly,
|
||||||
volatileStore: l.volatileStore,
|
volatileStore: l.volatileStore,
|
||||||
|
|
@ -745,6 +758,7 @@ func (r *layerStore) load(lockedForWriting bool) (bool, error) {
|
||||||
names := make(map[string]*Layer)
|
names := make(map[string]*Layer)
|
||||||
compressedsums := make(map[digest.Digest][]string)
|
compressedsums := make(map[digest.Digest][]string)
|
||||||
uncompressedsums := make(map[digest.Digest][]string)
|
uncompressedsums := make(map[digest.Digest][]string)
|
||||||
|
tocsums := make(map[digest.Digest][]string)
|
||||||
var errorToResolveBySaving error // == nil; if there are multiple errors, this is one of them.
|
var errorToResolveBySaving error // == nil; if there are multiple errors, this is one of them.
|
||||||
if r.lockfile.IsReadWrite() {
|
if r.lockfile.IsReadWrite() {
|
||||||
selinux.ClearLabels()
|
selinux.ClearLabels()
|
||||||
|
|
@ -765,6 +779,9 @@ func (r *layerStore) load(lockedForWriting bool) (bool, error) {
|
||||||
if layer.UncompressedDigest != "" {
|
if layer.UncompressedDigest != "" {
|
||||||
uncompressedsums[layer.UncompressedDigest] = append(uncompressedsums[layer.UncompressedDigest], layer.ID)
|
uncompressedsums[layer.UncompressedDigest] = append(uncompressedsums[layer.UncompressedDigest], layer.ID)
|
||||||
}
|
}
|
||||||
|
if layer.TOCDigest != "" {
|
||||||
|
tocsums[layer.TOCDigest] = append(tocsums[layer.TOCDigest], layer.ID)
|
||||||
|
}
|
||||||
if layer.MountLabel != "" {
|
if layer.MountLabel != "" {
|
||||||
selinux.ReserveLabel(layer.MountLabel)
|
selinux.ReserveLabel(layer.MountLabel)
|
||||||
}
|
}
|
||||||
|
|
@ -792,6 +809,7 @@ func (r *layerStore) load(lockedForWriting bool) (bool, error) {
|
||||||
r.byname = names
|
r.byname = names
|
||||||
r.bycompressedsum = compressedsums
|
r.bycompressedsum = compressedsums
|
||||||
r.byuncompressedsum = uncompressedsums
|
r.byuncompressedsum = uncompressedsums
|
||||||
|
r.bytocsum = tocsums
|
||||||
|
|
||||||
// Load and merge information about which layers are mounted, and where.
|
// Load and merge information about which layers are mounted, and where.
|
||||||
if r.lockfile.IsReadWrite() {
|
if r.lockfile.IsReadWrite() {
|
||||||
|
|
@ -1112,7 +1130,7 @@ func (r *layerStore) Size(name string) (int64, error) {
|
||||||
// We use the presence of a non-empty digest as an indicator that the size value was intentionally set, and that
|
// We use the presence of a non-empty digest as an indicator that the size value was intentionally set, and that
|
||||||
// a zero value is not just present because it was never set to anything else (which can happen if the layer was
|
// a zero value is not just present because it was never set to anything else (which can happen if the layer was
|
||||||
// created by a version of this library that didn't keep track of digest and size information).
|
// created by a version of this library that didn't keep track of digest and size information).
|
||||||
if layer.UncompressedDigest != "" {
|
if layer.TOCDigest != "" || layer.UncompressedDigest != "" {
|
||||||
return layer.UncompressedSize, nil
|
return layer.UncompressedSize, nil
|
||||||
}
|
}
|
||||||
return -1, nil
|
return -1, nil
|
||||||
|
|
@ -1201,6 +1219,9 @@ func (r *layerStore) PutAdditionalLayer(id string, parentLayer *Layer, names []s
|
||||||
if layer.UncompressedDigest != "" {
|
if layer.UncompressedDigest != "" {
|
||||||
r.byuncompressedsum[layer.UncompressedDigest] = append(r.byuncompressedsum[layer.UncompressedDigest], layer.ID)
|
r.byuncompressedsum[layer.UncompressedDigest] = append(r.byuncompressedsum[layer.UncompressedDigest], layer.ID)
|
||||||
}
|
}
|
||||||
|
if layer.TOCDigest != "" {
|
||||||
|
r.bytocsum[layer.TOCDigest] = append(r.bytocsum[layer.TOCDigest], layer.ID)
|
||||||
|
}
|
||||||
if err := r.saveFor(layer); err != nil {
|
if err := r.saveFor(layer); err != nil {
|
||||||
if e := r.Delete(layer.ID); e != nil {
|
if e := r.Delete(layer.ID); e != nil {
|
||||||
logrus.Errorf("While recovering from a failure to save layers, error deleting layer %#v: %v", id, e)
|
logrus.Errorf("While recovering from a failure to save layers, error deleting layer %#v: %v", id, e)
|
||||||
|
|
@ -1251,6 +1272,7 @@ func (r *layerStore) create(id string, parentLayer *Layer, names []string, mount
|
||||||
templateCompressedDigest digest.Digest
|
templateCompressedDigest digest.Digest
|
||||||
templateCompressedSize int64
|
templateCompressedSize int64
|
||||||
templateUncompressedDigest digest.Digest
|
templateUncompressedDigest digest.Digest
|
||||||
|
templateTOCDigest digest.Digest
|
||||||
templateUncompressedSize int64
|
templateUncompressedSize int64
|
||||||
templateCompressionType archive.Compression
|
templateCompressionType archive.Compression
|
||||||
templateUIDs, templateGIDs []uint32
|
templateUIDs, templateGIDs []uint32
|
||||||
|
|
@ -1263,6 +1285,7 @@ func (r *layerStore) create(id string, parentLayer *Layer, names []string, mount
|
||||||
}
|
}
|
||||||
templateMetadata = templateLayer.Metadata
|
templateMetadata = templateLayer.Metadata
|
||||||
templateIDMappings = idtools.NewIDMappingsFromMaps(templateLayer.UIDMap, templateLayer.GIDMap)
|
templateIDMappings = idtools.NewIDMappingsFromMaps(templateLayer.UIDMap, templateLayer.GIDMap)
|
||||||
|
templateTOCDigest = templateLayer.TOCDigest
|
||||||
templateCompressedDigest, templateCompressedSize = templateLayer.CompressedDigest, templateLayer.CompressedSize
|
templateCompressedDigest, templateCompressedSize = templateLayer.CompressedDigest, templateLayer.CompressedSize
|
||||||
templateUncompressedDigest, templateUncompressedSize = templateLayer.UncompressedDigest, templateLayer.UncompressedSize
|
templateUncompressedDigest, templateUncompressedSize = templateLayer.UncompressedDigest, templateLayer.UncompressedSize
|
||||||
templateCompressionType = templateLayer.CompressionType
|
templateCompressionType = templateLayer.CompressionType
|
||||||
|
|
@ -1291,6 +1314,7 @@ func (r *layerStore) create(id string, parentLayer *Layer, names []string, mount
|
||||||
CompressedDigest: templateCompressedDigest,
|
CompressedDigest: templateCompressedDigest,
|
||||||
CompressedSize: templateCompressedSize,
|
CompressedSize: templateCompressedSize,
|
||||||
UncompressedDigest: templateUncompressedDigest,
|
UncompressedDigest: templateUncompressedDigest,
|
||||||
|
TOCDigest: templateTOCDigest,
|
||||||
UncompressedSize: templateUncompressedSize,
|
UncompressedSize: templateUncompressedSize,
|
||||||
CompressionType: templateCompressionType,
|
CompressionType: templateCompressionType,
|
||||||
UIDs: templateUIDs,
|
UIDs: templateUIDs,
|
||||||
|
|
@ -1413,6 +1437,9 @@ func (r *layerStore) create(id string, parentLayer *Layer, names []string, mount
|
||||||
if layer.UncompressedDigest != "" {
|
if layer.UncompressedDigest != "" {
|
||||||
r.byuncompressedsum[layer.UncompressedDigest] = append(r.byuncompressedsum[layer.UncompressedDigest], layer.ID)
|
r.byuncompressedsum[layer.UncompressedDigest] = append(r.byuncompressedsum[layer.UncompressedDigest], layer.ID)
|
||||||
}
|
}
|
||||||
|
if layer.TOCDigest != "" {
|
||||||
|
r.bytocsum[layer.TOCDigest] = append(r.bytocsum[layer.TOCDigest], layer.ID)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
delete(layer.Flags, incompleteFlag)
|
delete(layer.Flags, incompleteFlag)
|
||||||
|
|
@ -2197,6 +2224,25 @@ func (r *layerStore) DiffSize(from, to string) (size int64, err error) {
|
||||||
return r.driver.DiffSize(to, r.layerMappings(toLayer), from, r.layerMappings(fromLayer), toLayer.MountLabel)
|
return r.driver.DiffSize(to, r.layerMappings(toLayer), from, r.layerMappings(fromLayer), toLayer.MountLabel)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func updateDigestMap(m *map[digest.Digest][]string, oldvalue, newvalue digest.Digest, id string) {
|
||||||
|
var newList []string
|
||||||
|
if oldvalue != "" {
|
||||||
|
for _, value := range (*m)[oldvalue] {
|
||||||
|
if value != id {
|
||||||
|
newList = append(newList, value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if len(newList) > 0 {
|
||||||
|
(*m)[oldvalue] = newList
|
||||||
|
} else {
|
||||||
|
delete(*m, oldvalue)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if newvalue != "" {
|
||||||
|
(*m)[newvalue] = append((*m)[newvalue], id)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Requires startWriting.
|
// Requires startWriting.
|
||||||
func (r *layerStore) ApplyDiff(to string, diff io.Reader) (size int64, err error) {
|
func (r *layerStore) ApplyDiff(to string, diff io.Reader) (size int64, err error) {
|
||||||
return r.applyDiffWithOptions(to, nil, diff)
|
return r.applyDiffWithOptions(to, nil, diff)
|
||||||
|
|
@ -2313,24 +2359,6 @@ func (r *layerStore) applyDiffWithOptions(to string, layerOptions *LayerOptions,
|
||||||
uncompressedDigest = uncompressedDigester.Digest()
|
uncompressedDigest = uncompressedDigester.Digest()
|
||||||
}
|
}
|
||||||
|
|
||||||
updateDigestMap := func(m *map[digest.Digest][]string, oldvalue, newvalue digest.Digest, id string) {
|
|
||||||
var newList []string
|
|
||||||
if oldvalue != "" {
|
|
||||||
for _, value := range (*m)[oldvalue] {
|
|
||||||
if value != id {
|
|
||||||
newList = append(newList, value)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if len(newList) > 0 {
|
|
||||||
(*m)[oldvalue] = newList
|
|
||||||
} else {
|
|
||||||
delete(*m, oldvalue)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if newvalue != "" {
|
|
||||||
(*m)[newvalue] = append((*m)[newvalue], id)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
updateDigestMap(&r.bycompressedsum, layer.CompressedDigest, compressedDigest, layer.ID)
|
updateDigestMap(&r.bycompressedsum, layer.CompressedDigest, compressedDigest, layer.ID)
|
||||||
layer.CompressedDigest = compressedDigest
|
layer.CompressedDigest = compressedDigest
|
||||||
layer.CompressedSize = compressedCounter.Count
|
layer.CompressedSize = compressedCounter.Count
|
||||||
|
|
@ -2372,7 +2400,7 @@ func (r *layerStore) DifferTarget(id string) (string, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Requires startWriting.
|
// Requires startWriting.
|
||||||
func (r *layerStore) ApplyDiffFromStagingDirectory(id, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffOpts) error {
|
func (r *layerStore) ApplyDiffFromStagingDirectory(id, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffWithDifferOpts) error {
|
||||||
ddriver, ok := r.driver.(drivers.DriverWithDiffer)
|
ddriver, ok := r.driver.(drivers.DriverWithDiffer)
|
||||||
if !ok {
|
if !ok {
|
||||||
return ErrNotSupported
|
return ErrNotSupported
|
||||||
|
|
@ -2382,20 +2410,35 @@ func (r *layerStore) ApplyDiffFromStagingDirectory(id, stagingDirectory string,
|
||||||
return ErrLayerUnknown
|
return ErrLayerUnknown
|
||||||
}
|
}
|
||||||
if options == nil {
|
if options == nil {
|
||||||
options = &drivers.ApplyDiffOpts{
|
options = &drivers.ApplyDiffWithDifferOpts{
|
||||||
|
ApplyDiffOpts: drivers.ApplyDiffOpts{
|
||||||
Mappings: r.layerMappings(layer),
|
Mappings: r.layerMappings(layer),
|
||||||
MountLabel: layer.MountLabel,
|
MountLabel: layer.MountLabel,
|
||||||
|
},
|
||||||
|
Flags: nil,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
err := ddriver.ApplyDiffFromStagingDirectory(layer.ID, layer.Parent, stagingDirectory, diffOutput, options)
|
err := ddriver.ApplyDiffFromStagingDirectory(layer.ID, layer.Parent, stagingDirectory, diffOutput, options)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
layer.UIDs = diffOutput.UIDs
|
layer.UIDs = diffOutput.UIDs
|
||||||
layer.GIDs = diffOutput.GIDs
|
layer.GIDs = diffOutput.GIDs
|
||||||
|
updateDigestMap(&r.byuncompressedsum, layer.UncompressedDigest, diffOutput.UncompressedDigest, layer.ID)
|
||||||
layer.UncompressedDigest = diffOutput.UncompressedDigest
|
layer.UncompressedDigest = diffOutput.UncompressedDigest
|
||||||
|
updateDigestMap(&r.bytocsum, diffOutput.TOCDigest, diffOutput.TOCDigest, layer.ID)
|
||||||
|
layer.TOCDigest = diffOutput.TOCDigest
|
||||||
layer.UncompressedSize = diffOutput.Size
|
layer.UncompressedSize = diffOutput.Size
|
||||||
layer.Metadata = diffOutput.Metadata
|
layer.Metadata = diffOutput.Metadata
|
||||||
|
if options != nil && options.Flags != nil {
|
||||||
|
if layer.Flags == nil {
|
||||||
|
layer.Flags = make(map[string]interface{})
|
||||||
|
}
|
||||||
|
for k, v := range options.Flags {
|
||||||
|
layer.Flags[k] = v
|
||||||
|
}
|
||||||
|
}
|
||||||
if len(diffOutput.TarSplit) != 0 {
|
if len(diffOutput.TarSplit) != 0 {
|
||||||
tsdata := bytes.Buffer{}
|
tsdata := bytes.Buffer{}
|
||||||
compressor, err := pgzip.NewWriterLevel(&tsdata, pgzip.BestSpeed)
|
compressor, err := pgzip.NewWriterLevel(&tsdata, pgzip.BestSpeed)
|
||||||
|
|
@ -2432,7 +2475,7 @@ func (r *layerStore) ApplyDiffFromStagingDirectory(id, stagingDirectory string,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Requires startWriting.
|
// Requires startWriting.
|
||||||
func (r *layerStore) ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error) {
|
func (r *layerStore) ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffWithDifferOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error) {
|
||||||
ddriver, ok := r.driver.(drivers.DriverWithDiffer)
|
ddriver, ok := r.driver.(drivers.DriverWithDiffer)
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, ErrNotSupported
|
return nil, ErrNotSupported
|
||||||
|
|
@ -2448,9 +2491,11 @@ func (r *layerStore) ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffOp
|
||||||
return nil, ErrLayerUnknown
|
return nil, ErrLayerUnknown
|
||||||
}
|
}
|
||||||
if options == nil {
|
if options == nil {
|
||||||
options = &drivers.ApplyDiffOpts{
|
options = &drivers.ApplyDiffWithDifferOpts{
|
||||||
|
ApplyDiffOpts: drivers.ApplyDiffOpts{
|
||||||
Mappings: r.layerMappings(layer),
|
Mappings: r.layerMappings(layer),
|
||||||
MountLabel: layer.MountLabel,
|
MountLabel: layer.MountLabel,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
output, err := ddriver.ApplyDiffWithDiffer(layer.ID, layer.Parent, options, differ)
|
output, err := ddriver.ApplyDiffWithDiffer(layer.ID, layer.Parent, options, differ)
|
||||||
|
|
@ -2494,6 +2539,11 @@ func (r *layerStore) LayersByUncompressedDigest(d digest.Digest) ([]Layer, error
|
||||||
return r.layersByDigestMap(r.byuncompressedsum, d)
|
return r.layersByDigestMap(r.byuncompressedsum, d)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Requires startReading or startWriting.
|
||||||
|
func (r *layerStore) LayersByTOCDigest(d digest.Digest) ([]Layer, error) {
|
||||||
|
return r.layersByDigestMap(r.bytocsum, d)
|
||||||
|
}
|
||||||
|
|
||||||
func closeAll(closes ...func() error) (rErr error) {
|
func closeAll(closes ...func() error) (rErr error) {
|
||||||
for _, f := range closes {
|
for _, f := range closes {
|
||||||
if err := f(); err != nil {
|
if err := f(); err != nil {
|
||||||
|
|
|
||||||
|
|
@ -315,10 +315,10 @@ type Store interface {
|
||||||
// ApplyDiffer applies a diff to a layer.
|
// ApplyDiffer applies a diff to a layer.
|
||||||
// It is the caller responsibility to clean the staging directory if it is not
|
// It is the caller responsibility to clean the staging directory if it is not
|
||||||
// successfully applied with ApplyDiffFromStagingDirectory.
|
// successfully applied with ApplyDiffFromStagingDirectory.
|
||||||
ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error)
|
ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffWithDifferOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error)
|
||||||
|
|
||||||
// ApplyDiffFromStagingDirectory uses stagingDirectory to create the diff.
|
// ApplyDiffFromStagingDirectory uses stagingDirectory to create the diff.
|
||||||
ApplyDiffFromStagingDirectory(to, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffOpts) error
|
ApplyDiffFromStagingDirectory(to, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffWithDifferOpts) error
|
||||||
|
|
||||||
// CleanupStagingDirectory cleanups the staging directory. It can be used to cleanup the staging directory on errors
|
// CleanupStagingDirectory cleanups the staging directory. It can be used to cleanup the staging directory on errors
|
||||||
CleanupStagingDirectory(stagingDirectory string) error
|
CleanupStagingDirectory(stagingDirectory string) error
|
||||||
|
|
@ -334,6 +334,10 @@ type Store interface {
|
||||||
// specified uncompressed digest value recorded for them.
|
// specified uncompressed digest value recorded for them.
|
||||||
LayersByUncompressedDigest(d digest.Digest) ([]Layer, error)
|
LayersByUncompressedDigest(d digest.Digest) ([]Layer, error)
|
||||||
|
|
||||||
|
// LayersByTOCDigest returns a slice of the layers with the
|
||||||
|
// specified TOC digest value recorded for them.
|
||||||
|
LayersByTOCDigest(d digest.Digest) ([]Layer, error)
|
||||||
|
|
||||||
// LayerSize returns a cached approximation of the layer's size, or -1
|
// LayerSize returns a cached approximation of the layer's size, or -1
|
||||||
// if we don't have a value on hand.
|
// if we don't have a value on hand.
|
||||||
LayerSize(id string) (int64, error)
|
LayerSize(id string) (int64, error)
|
||||||
|
|
@ -2927,7 +2931,7 @@ func (s *store) Diff(from, to string, options *DiffOptions) (io.ReadCloser, erro
|
||||||
return nil, ErrLayerUnknown
|
return nil, ErrLayerUnknown
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *store) ApplyDiffFromStagingDirectory(to, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffOpts) error {
|
func (s *store) ApplyDiffFromStagingDirectory(to, stagingDirectory string, diffOutput *drivers.DriverWithDifferOutput, options *drivers.ApplyDiffWithDifferOpts) error {
|
||||||
_, err := writeToLayerStore(s, func(rlstore rwLayerStore) (struct{}, error) {
|
_, err := writeToLayerStore(s, func(rlstore rwLayerStore) (struct{}, error) {
|
||||||
if !rlstore.Exists(to) {
|
if !rlstore.Exists(to) {
|
||||||
return struct{}{}, ErrLayerUnknown
|
return struct{}{}, ErrLayerUnknown
|
||||||
|
|
@ -2944,7 +2948,7 @@ func (s *store) CleanupStagingDirectory(stagingDirectory string) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *store) ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error) {
|
func (s *store) ApplyDiffWithDiffer(to string, options *drivers.ApplyDiffWithDifferOpts, differ drivers.Differ) (*drivers.DriverWithDifferOutput, error) {
|
||||||
return writeToLayerStore(s, func(rlstore rwLayerStore) (*drivers.DriverWithDifferOutput, error) {
|
return writeToLayerStore(s, func(rlstore rwLayerStore) (*drivers.DriverWithDifferOutput, error) {
|
||||||
if to != "" && !rlstore.Exists(to) {
|
if to != "" && !rlstore.Exists(to) {
|
||||||
return nil, ErrLayerUnknown
|
return nil, ErrLayerUnknown
|
||||||
|
|
@ -3006,6 +3010,13 @@ func (s *store) LayersByUncompressedDigest(d digest.Digest) ([]Layer, error) {
|
||||||
return s.layersByMappedDigest(func(r roLayerStore, d digest.Digest) ([]Layer, error) { return r.LayersByUncompressedDigest(d) }, d)
|
return s.layersByMappedDigest(func(r roLayerStore, d digest.Digest) ([]Layer, error) { return r.LayersByUncompressedDigest(d) }, d)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (s *store) LayersByTOCDigest(d digest.Digest) ([]Layer, error) {
|
||||||
|
if err := d.Validate(); err != nil {
|
||||||
|
return nil, fmt.Errorf("looking for TOC matching digest %q: %w", d, err)
|
||||||
|
}
|
||||||
|
return s.layersByMappedDigest(func(r roLayerStore, d digest.Digest) ([]Layer, error) { return r.LayersByTOCDigest(d) }, d)
|
||||||
|
}
|
||||||
|
|
||||||
func (s *store) LayerSize(id string) (int64, error) {
|
func (s *store) LayerSize(id string) (int64, error) {
|
||||||
if res, done, err := readAllLayerStores(s, func(store roLayerStore) (int64, bool, error) {
|
if res, done, err := readAllLayerStores(s, func(store roLayerStore) (int64, bool, error) {
|
||||||
if store.Exists(id) {
|
if store.Exists(id) {
|
||||||
|
|
|
||||||
|
|
@ -1,44 +0,0 @@
|
||||||
// Copyright 2018 Klaus Post. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style
|
|
||||||
// license that can be found in the LICENSE file.
|
|
||||||
// Based on work Copyright (c) 2013, Yann Collet, released under BSD License.
|
|
||||||
|
|
||||||
package huff0
|
|
||||||
|
|
||||||
// byteReader provides a byte reader that reads
|
|
||||||
// little endian values from a byte stream.
|
|
||||||
// The input stream is manually advanced.
|
|
||||||
// The reader performs no bounds checks.
|
|
||||||
type byteReader struct {
|
|
||||||
b []byte
|
|
||||||
off int
|
|
||||||
}
|
|
||||||
|
|
||||||
// init will initialize the reader and set the input.
|
|
||||||
func (b *byteReader) init(in []byte) {
|
|
||||||
b.b = in
|
|
||||||
b.off = 0
|
|
||||||
}
|
|
||||||
|
|
||||||
// Int32 returns a little endian int32 starting at current offset.
|
|
||||||
func (b byteReader) Int32() int32 {
|
|
||||||
v3 := int32(b.b[b.off+3])
|
|
||||||
v2 := int32(b.b[b.off+2])
|
|
||||||
v1 := int32(b.b[b.off+1])
|
|
||||||
v0 := int32(b.b[b.off])
|
|
||||||
return (v3 << 24) | (v2 << 16) | (v1 << 8) | v0
|
|
||||||
}
|
|
||||||
|
|
||||||
// Uint32 returns a little endian uint32 starting at current offset.
|
|
||||||
func (b byteReader) Uint32() uint32 {
|
|
||||||
v3 := uint32(b.b[b.off+3])
|
|
||||||
v2 := uint32(b.b[b.off+2])
|
|
||||||
v1 := uint32(b.b[b.off+1])
|
|
||||||
v0 := uint32(b.b[b.off])
|
|
||||||
return (v3 << 24) | (v2 << 16) | (v1 << 8) | v0
|
|
||||||
}
|
|
||||||
|
|
||||||
// remain will return the number of bytes remaining.
|
|
||||||
func (b byteReader) remain() int {
|
|
||||||
return len(b.b) - b.off
|
|
||||||
}
|
|
||||||
|
|
@ -350,6 +350,7 @@ func (s *Scratch) compress4Xp(src []byte) ([]byte, error) {
|
||||||
// Does not update s.clearCount.
|
// Does not update s.clearCount.
|
||||||
func (s *Scratch) countSimple(in []byte) (max int, reuse bool) {
|
func (s *Scratch) countSimple(in []byte) (max int, reuse bool) {
|
||||||
reuse = true
|
reuse = true
|
||||||
|
_ = s.count // Assert that s != nil to speed up the following loop.
|
||||||
for _, v := range in {
|
for _, v := range in {
|
||||||
s.count[v]++
|
s.count[v]++
|
||||||
}
|
}
|
||||||
|
|
@ -415,7 +416,7 @@ func (s *Scratch) validateTable(c cTable) bool {
|
||||||
|
|
||||||
// minTableLog provides the minimum logSize to safely represent a distribution.
|
// minTableLog provides the minimum logSize to safely represent a distribution.
|
||||||
func (s *Scratch) minTableLog() uint8 {
|
func (s *Scratch) minTableLog() uint8 {
|
||||||
minBitsSrc := highBit32(uint32(s.br.remain())) + 1
|
minBitsSrc := highBit32(uint32(s.srcLen)) + 1
|
||||||
minBitsSymbols := highBit32(uint32(s.symbolLen-1)) + 2
|
minBitsSymbols := highBit32(uint32(s.symbolLen-1)) + 2
|
||||||
if minBitsSrc < minBitsSymbols {
|
if minBitsSrc < minBitsSymbols {
|
||||||
return uint8(minBitsSrc)
|
return uint8(minBitsSrc)
|
||||||
|
|
@ -427,7 +428,7 @@ func (s *Scratch) minTableLog() uint8 {
|
||||||
func (s *Scratch) optimalTableLog() {
|
func (s *Scratch) optimalTableLog() {
|
||||||
tableLog := s.TableLog
|
tableLog := s.TableLog
|
||||||
minBits := s.minTableLog()
|
minBits := s.minTableLog()
|
||||||
maxBitsSrc := uint8(highBit32(uint32(s.br.remain()-1))) - 1
|
maxBitsSrc := uint8(highBit32(uint32(s.srcLen-1))) - 1
|
||||||
if maxBitsSrc < tableLog {
|
if maxBitsSrc < tableLog {
|
||||||
// Accuracy can be reduced
|
// Accuracy can be reduced
|
||||||
tableLog = maxBitsSrc
|
tableLog = maxBitsSrc
|
||||||
|
|
|
||||||
|
|
@ -88,7 +88,7 @@ type Scratch struct {
|
||||||
// Decoders will return ErrMaxDecodedSizeExceeded is this limit is exceeded.
|
// Decoders will return ErrMaxDecodedSizeExceeded is this limit is exceeded.
|
||||||
MaxDecodedSize int
|
MaxDecodedSize int
|
||||||
|
|
||||||
br byteReader
|
srcLen int
|
||||||
|
|
||||||
// MaxSymbolValue will override the maximum symbol value of the next block.
|
// MaxSymbolValue will override the maximum symbol value of the next block.
|
||||||
MaxSymbolValue uint8
|
MaxSymbolValue uint8
|
||||||
|
|
@ -170,7 +170,7 @@ func (s *Scratch) prepare(in []byte) (*Scratch, error) {
|
||||||
if s.fse == nil {
|
if s.fse == nil {
|
||||||
s.fse = &fse.Scratch{}
|
s.fse = &fse.Scratch{}
|
||||||
}
|
}
|
||||||
s.br.init(in)
|
s.srcLen = len(in)
|
||||||
|
|
||||||
return s, nil
|
return s, nil
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -259,7 +259,7 @@ nyc-taxi-data-10M.csv gzkp 1 3325605752 922273214 13929 227.68
|
||||||
|
|
||||||
## Decompressor
|
## Decompressor
|
||||||
|
|
||||||
Staus: STABLE - there may still be subtle bugs, but a wide variety of content has been tested.
|
Status: STABLE - there may still be subtle bugs, but a wide variety of content has been tested.
|
||||||
|
|
||||||
This library is being continuously [fuzz-tested](https://github.com/klauspost/compress-fuzz),
|
This library is being continuously [fuzz-tested](https://github.com/klauspost/compress-fuzz),
|
||||||
kindly supplied by [fuzzit.dev](https://fuzzit.dev/).
|
kindly supplied by [fuzzit.dev](https://fuzzit.dev/).
|
||||||
|
|
|
||||||
|
|
@ -344,7 +344,7 @@ github.com/containers/psgo/internal/dev
|
||||||
github.com/containers/psgo/internal/host
|
github.com/containers/psgo/internal/host
|
||||||
github.com/containers/psgo/internal/proc
|
github.com/containers/psgo/internal/proc
|
||||||
github.com/containers/psgo/internal/process
|
github.com/containers/psgo/internal/process
|
||||||
# github.com/containers/storage v1.51.1-0.20231129190156-7d0a0a320f8a
|
# github.com/containers/storage v1.51.1-0.20231205203947-fe005407c7d5
|
||||||
## explicit; go 1.19
|
## explicit; go 1.19
|
||||||
github.com/containers/storage
|
github.com/containers/storage
|
||||||
github.com/containers/storage/drivers
|
github.com/containers/storage/drivers
|
||||||
|
|
@ -700,7 +700,7 @@ github.com/josharian/intern
|
||||||
# github.com/json-iterator/go v1.1.12
|
# github.com/json-iterator/go v1.1.12
|
||||||
## explicit; go 1.12
|
## explicit; go 1.12
|
||||||
github.com/json-iterator/go
|
github.com/json-iterator/go
|
||||||
# github.com/klauspost/compress v1.17.3
|
# github.com/klauspost/compress v1.17.4
|
||||||
## explicit; go 1.19
|
## explicit; go 1.19
|
||||||
github.com/klauspost/compress
|
github.com/klauspost/compress
|
||||||
github.com/klauspost/compress/flate
|
github.com/klauspost/compress/flate
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue