dotcloud/docker

View on GitHub
image/rootfs.go

Summary

Maintainability
A
0 mins
Test Coverage
package image // import "github.com/docker/docker/image"

import (
    "context"
    "runtime"

    "github.com/containerd/log"
    "github.com/docker/docker/layer"
)

// TypeLayers is used for RootFS.Type for filesystems organized into layers.
const TypeLayers = "layers"

// typeLayersWithBase is an older format used by Windows up to v1.12. We
// explicitly handle this as an error case to ensure that a daemon which still
// has an older image like this on disk can still start, even though the
// image itself is not usable. See https://github.com/docker/docker/pull/25806.
const typeLayersWithBase = "layers+base"

// RootFS describes images root filesystem
// This is currently a placeholder that only supports layers. In the future
// this can be made into an interface that supports different implementations.
type RootFS struct {
    Type    string         `json:"type"`
    DiffIDs []layer.DiffID `json:"diff_ids,omitempty"`
}

// NewRootFS returns empty RootFS struct
func NewRootFS() *RootFS {
    return &RootFS{Type: TypeLayers}
}

// Append appends a new diffID to rootfs
func (r *RootFS) Append(id layer.DiffID) {
    r.DiffIDs = append(r.DiffIDs, id)
}

// Clone returns a copy of the RootFS
func (r *RootFS) Clone() *RootFS {
    newRoot := NewRootFS()
    newRoot.Type = r.Type
    newRoot.DiffIDs = make([]layer.DiffID, len(r.DiffIDs))
    copy(newRoot.DiffIDs, r.DiffIDs)
    return newRoot
}

// ChainID returns the ChainID for the top layer in RootFS.
func (r *RootFS) ChainID() layer.ChainID {
    if runtime.GOOS == "windows" && r.Type == typeLayersWithBase {
        log.G(context.TODO()).Warnf("Layer type is unsupported on this platform. DiffIDs: '%v'", r.DiffIDs)
        return ""
    }
    return layer.CreateChainID(r.DiffIDs)
}