package system
import "github.com/docker/docker/pkg/system"
Index ¶
- Variables
- func CheckSystemDriveAndRemoveDriveLetter(path string, driver PathVerifier) (string, error)
- func Chtimes(name string, atime time.Time, mtime time.Time) error
- func CreateSequential(name string) (*os.File, error)
- func DefaultPathEnv(os string) string
- func GetLongPathName(path string) (string, error)
- func IsAbs(path string) bool
- func IsOSSupported(os string) bool
- func LUtimesNano(path string, ts []syscall.Timespec) error
- func Lgetxattr(path string, attr string) ([]byte, error)
- func Lsetxattr(path string, attr string, data []byte, flags int) error
- func Mkdev(major int64, minor int64) uint32
- func MkdirAll(path string, perm os.FileMode) error
- func MkdirAllWithACL(path string, perm os.FileMode, sddl string) error
- func Mknod(path string, mode uint32, dev int) error
- func OpenFileSequential(name string, flag int, perm os.FileMode) (*os.File, error)
- func OpenSequential(name string) (*os.File, error)
- func TempFileSequential(dir, prefix string) (f *os.File, err error)
- type MemInfo
- type PathVerifier
- type StatT
Variables ¶
var ( // ErrNotSupportedPlatform means the platform is not supported. ErrNotSupportedPlatform = errors.New("platform and architecture is not supported") // ErrNotSupportedOperatingSystem means the operating system is not supported. ErrNotSupportedOperatingSystem = errors.New("operating system is not supported") )
Functions ¶
func CheckSystemDriveAndRemoveDriveLetter ¶
func CheckSystemDriveAndRemoveDriveLetter(path string, driver PathVerifier) (string, error)
CheckSystemDriveAndRemoveDriveLetter verifies that a path, if it includes a drive letter, is the system drive. On Linux: this is a no-op. On Windows: this does the following> CheckSystemDriveAndRemoveDriveLetter verifies and manipulates a Windows path. This is used, for example, when validating a user provided path in docker cp. If a drive letter is supplied, it must be the system drive. The drive letter is always removed. Also, it translates it to OS semantics (IOW / to \). We need the path in this syntax so that it can ultimately be concatenated with a Windows long-path which doesn't support drive-letters. Examples: C: --> Fail C:\ --> \ a --> a /a --> \a d:\ --> Fail
func Chtimes ¶
Chtimes changes the access time and modified time of a file at the given path
func CreateSequential ¶
CreateSequential is deprecated.
Deprecated: use os.Create or github.com/moby/sys/sequential.Create()
func DefaultPathEnv ¶
DefaultPathEnv is unix style list of directories to search for executables. Each directory is separated from the next by a colon ':' character . For Windows containers, an empty string is returned as the default path will be set by the container, and Docker has no context of what the default path should be.
func GetLongPathName ¶
GetLongPathName converts Windows short pathnames to full pathnames. For example C:\Users\ADMIN~1 --> C:\Users\Administrator. It is a no-op on non-Windows platforms
func IsAbs ¶
IsAbs is a platform-agnostic wrapper for filepath.IsAbs.
On Windows, golang filepath.IsAbs does not consider a path \windows\system32 as absolute as it doesn't start with a drive-letter/colon combination. However, in docker we need to verify things such as WORKDIR /windows/system32 in a Dockerfile (which gets translated to \windows\system32 when being processed by the daemon). This SHOULD be treated as absolute from a docker processing perspective.
func IsOSSupported ¶
IsOSSupported determines if an operating system is supported by the host.
func LUtimesNano ¶
LUtimesNano is only supported on linux and freebsd.
func Lgetxattr ¶
Lgetxattr is not supported on platforms other than linux.
func Lsetxattr ¶
Lsetxattr is not supported on platforms other than linux.
func Mkdev ¶
Mkdev is used to build the value of linux devices (in /dev/) which specifies major and minor number of the newly created device special file. Linux device nodes are a bit weird due to backwards compat with 16 bit device nodes. They are, from low to high: the lower 8 bits of the minor, then 12 bits of the major, then the top 12 bits of the minor.
func MkdirAll ¶
MkdirAll creates a directory named path along with any necessary parents, with permission specified by attribute perm for all dir created.
func MkdirAllWithACL ¶
MkdirAllWithACL is a wrapper for os.MkdirAll on unix systems.
func Mknod ¶
Mknod creates a filesystem node (file, device special file or named pipe) named path with attributes specified by mode and dev.
func OpenFileSequential ¶
OpenFileSequential is deprecated.
Deprecated: use github.com/moby/sys/sequential.OpenFile()
func OpenSequential ¶
OpenSequential is deprecated.
Deprecated: use os.Open or github.com/moby/sys/sequential.Open
func TempFileSequential ¶
TempFileSequential is deprecated.
Deprecated: use os.CreateTemp or github.com/moby/sys/sequential.CreateTemp
Types ¶
type MemInfo ¶
type MemInfo struct { // Total usable RAM (i.e. physical RAM minus a few reserved bits and the // kernel binary code). MemTotal int64 // Amount of free memory. MemFree int64 // Total amount of swap space available. SwapTotal int64 // Amount of swap space that is currently unused. SwapFree int64 }
MemInfo contains memory statistics of the host system.
func ReadMemInfo ¶
ReadMemInfo is not supported on platforms other than linux and windows.
type PathVerifier ¶
PathVerifier defines the subset of a PathDriver that CheckSystemDriveAndRemoveDriveLetter actually uses in order to avoid system depending on containerd/continuity.
type StatT ¶
type StatT struct {
// contains filtered or unexported fields
}
StatT type contains status of a file. It contains metadata like permission, owner, group, size, etc about a file.
func Lstat ¶
Lstat takes a path to a file and returns a system.StatT type pertaining to that file.
Throws an error if the file does not exist
func Stat ¶
Stat takes a path to a file and returns a system.StatT type pertaining to that file.
Throws an error if the file does not exist
func (StatT) GID ¶
GID returns file's group id of owner.
func (StatT) IsDir ¶
IsDir reports whether s describes a directory.
func (StatT) Mode ¶
Mode returns file's permission mode.
func (StatT) Mtim ¶
Mtim returns file's last modification time.
func (StatT) Rdev ¶
Rdev returns file's device ID (if it's special file).
func (StatT) Size ¶
Size returns file's size.
func (StatT) UID ¶
UID returns file's user id of owner.
Source Files ¶
chtimes.go chtimes_nowindows.go errors.go filesys.go filesys_deprecated.go filesys_unix.go image_os.go init.go lstat_unix.go meminfo.go meminfo_unsupported.go mknod.go mknod_unix.go path.go path_unix.go stat_unix.go utimes_unsupported.go xattrs_unsupported.go
- Version
- v23.0.11+incompatible
- Published
- Apr 9, 2024
- Platform
- js/wasm
- Imports
- 10 packages
- Last checked
- 4 seconds ago –
Tools for package owners.