Merge pull request #11323 from delftswa2014/utils-daemon-windows

Make utils_daemon and volumes.go cross-platform compileable (Windows).
This commit is contained in:
Alexander Morozov 2015-03-16 12:14:30 -07:00
commit f9b208001f
7 changed files with 30 additions and 16 deletions

View file

@ -143,7 +143,7 @@ func Changes(layers []string, rw string) ([]Change, error) {
type FileInfo struct {
parent *FileInfo
name string
stat *system.Stat
stat *system.Stat_t
children map[string]*FileInfo
capability []byte
added bool

View file

@ -6,7 +6,7 @@ import (
"syscall"
)
func Lstat(path string) (*Stat, error) {
func Lstat(path string) (*Stat_t, error) {
s := &syscall.Stat_t{}
err := syscall.Lstat(path, s)
if err != nil {

View file

@ -2,7 +2,7 @@
package system
func Lstat(path string) (*Stat, error) {
func Lstat(path string) (*Stat_t, error) {
// should not be called on cli code path
return nil, ErrNotSupportedPlatform
}

View file

@ -4,7 +4,7 @@ import (
"syscall"
)
type Stat struct {
type Stat_t struct {
mode uint32
uid uint32
gid uint32
@ -13,30 +13,30 @@ type Stat struct {
mtim syscall.Timespec
}
func (s Stat) Mode() uint32 {
func (s Stat_t) Mode() uint32 {
return s.mode
}
func (s Stat) Uid() uint32 {
func (s Stat_t) Uid() uint32 {
return s.uid
}
func (s Stat) Gid() uint32 {
func (s Stat_t) Gid() uint32 {
return s.gid
}
func (s Stat) Rdev() uint64 {
func (s Stat_t) Rdev() uint64 {
return s.rdev
}
func (s Stat) Size() int64 {
func (s Stat_t) Size() int64 {
return s.size
}
func (s Stat) Mtim() syscall.Timespec {
func (s Stat_t) Mtim() syscall.Timespec {
return s.mtim
}
func (s Stat) GetLastModification() syscall.Timespec {
func (s Stat_t) GetLastModification() syscall.Timespec {
return s.Mtim()
}

View file

@ -4,11 +4,20 @@ import (
"syscall"
)
func fromStatT(s *syscall.Stat_t) (*Stat, error) {
return &Stat{size: s.Size,
func fromStatT(s *syscall.Stat_t) (*Stat_t, error) {
return &Stat_t{size: s.Size,
mode: s.Mode,
uid: s.Uid,
gid: s.Gid,
rdev: s.Rdev,
mtim: s.Mtim}, nil
}
func Stat(path string) (*Stat_t, error) {
s := &syscall.Stat_t{}
err := syscall.Stat(path, s)
if err != nil {
return nil, err
}
return fromStatT(s)
}

View file

@ -6,8 +6,8 @@ import (
"syscall"
)
func fromStatT(s *syscall.Stat_t) (*Stat, error) {
return &Stat{size: s.Size,
func fromStatT(s *syscall.Stat_t) (*Stat_t, error) {
return &Stat_t{size: s.Size,
mode: uint32(s.Mode),
uid: s.Uid,
gid: s.Gid,

View file

@ -7,6 +7,11 @@ import (
"syscall"
)
func fromStatT(s *syscall.Win32FileAttributeData) (*Stat, error) {
func fromStatT(s *syscall.Win32FileAttributeData) (*Stat_t, error) {
return nil, errors.New("fromStatT should not be called on windows path")
}
func Stat(path string) (*Stat_t, error) {
// should not be called on cli code path
return nil, ErrNotSupportedPlatform
}