123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- // +build windows
- package daemon
- import (
- "fmt"
- "sort"
- "github.com/docker/docker/container"
- "github.com/docker/docker/volume"
- )
- // setupMounts configures the mount points for a container by appending each
- // of the configured mounts on the container to the OCI mount structure
- // which will ultimately be passed into the oci runtime during container creation.
- // It also ensures each of the mounts are lexographically sorted.
- // BUGBUG TODO Windows containerd. This would be much better if it returned
- // an array of windowsoci mounts, not container mounts. Then no need to
- // do multiple transitions.
- func (daemon *Daemon) setupMounts(c *container.Container) ([]container.Mount, error) {
- var mnts []container.Mount
- for _, mount := range c.MountPoints { // type is volume.MountPoint
- if err := daemon.lazyInitializeVolume(c.ID, mount); err != nil {
- return nil, err
- }
- // If there is no source, take it from the volume path
- s := mount.Source
- if s == "" && mount.Volume != nil {
- s = mount.Volume.Path()
- }
- if s == "" {
- return nil, fmt.Errorf("No source for mount name '%s' driver %q destination '%s'", mount.Name, mount.Driver, mount.Destination)
- }
- mnts = append(mnts, container.Mount{
- Source: s,
- Destination: mount.Destination,
- Writable: mount.RW,
- })
- }
- sort.Sort(mounts(mnts))
- return mnts, nil
- }
- // setBindModeIfNull is platform specific processing which is a no-op on
- // Windows.
- func setBindModeIfNull(bind *volume.MountPoint) *volume.MountPoint {
- return bind
- }
|