mirror of
https://github.com/moby/moby.git
synced 2022-11-09 12:21:53 -05:00
Merge pull request #4878 from kzys/freebsd-utimes
Support FreeBSD on pkg/system/utimes_*.go
This commit is contained in:
commit
f98ed28c1d
4 changed files with 100 additions and 2 deletions
12
hack/make.sh
12
hack/make.sh
|
@ -107,6 +107,16 @@ LDFLAGS_STATIC_DOCKER="
|
||||||
-extldflags \"$EXTLDFLAGS_STATIC_DOCKER\"
|
-extldflags \"$EXTLDFLAGS_STATIC_DOCKER\"
|
||||||
"
|
"
|
||||||
|
|
||||||
|
if [ "$(uname -s)" = 'FreeBSD' ]; then
|
||||||
|
# Tell cgo the compiler is Clang, not GCC
|
||||||
|
# https://code.google.com/p/go/source/browse/src/cmd/cgo/gcc.go?spec=svne77e74371f2340ee08622ce602e9f7b15f29d8d3&r=e6794866ebeba2bf8818b9261b54e2eef1c9e588#752
|
||||||
|
export CC=clang
|
||||||
|
|
||||||
|
# "-extld clang" is a workaround for
|
||||||
|
# https://code.google.com/p/go/issues/detail?id=6845
|
||||||
|
LDFLAGS="$LDFLAGS -extld clang"
|
||||||
|
fi
|
||||||
|
|
||||||
HAVE_GO_TEST_COVER=
|
HAVE_GO_TEST_COVER=
|
||||||
if \
|
if \
|
||||||
go help testflag | grep -- -cover > /dev/null \
|
go help testflag | grep -- -cover > /dev/null \
|
||||||
|
@ -142,7 +152,7 @@ go_test_dir() {
|
||||||
# holding certain files ($1 parameter), and prints their paths on standard
|
# holding certain files ($1 parameter), and prints their paths on standard
|
||||||
# output, one per line.
|
# output, one per line.
|
||||||
find_dirs() {
|
find_dirs() {
|
||||||
find -not \( \
|
find . -not \( \
|
||||||
\( \
|
\( \
|
||||||
-wholename './vendor' \
|
-wholename './vendor' \
|
||||||
-o -wholename './integration' \
|
-o -wholename './integration' \
|
||||||
|
|
24
pkg/system/utimes_freebsd.go
Normal file
24
pkg/system/utimes_freebsd.go
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"syscall"
|
||||||
|
"unsafe"
|
||||||
|
)
|
||||||
|
|
||||||
|
func LUtimesNano(path string, ts []syscall.Timespec) error {
|
||||||
|
var _path *byte
|
||||||
|
_path, err := syscall.BytePtrFromString(path)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
if _, _, err := syscall.Syscall(syscall.SYS_LUTIMES, uintptr(unsafe.Pointer(_path)), uintptr(unsafe.Pointer(&ts[0])), 0); err != 0 && err != syscall.ENOSYS {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func UtimesNano(path string, ts []syscall.Timespec) error {
|
||||||
|
return syscall.UtimesNano(path, ts)
|
||||||
|
}
|
64
pkg/system/utimes_test.go
Normal file
64
pkg/system/utimes_test.go
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"syscall"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func prepareFiles(t *testing.T) (string, string, string) {
|
||||||
|
dir, err := ioutil.TempDir("", "docker-system-test")
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
file := filepath.Join(dir, "exist")
|
||||||
|
if err := ioutil.WriteFile(file, []byte("hello"), 0644); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
invalid := filepath.Join(dir, "doesnt-exist")
|
||||||
|
|
||||||
|
symlink := filepath.Join(dir, "symlink")
|
||||||
|
if err := os.Symlink(file, symlink); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return file, invalid, symlink
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestLUtimesNano(t *testing.T) {
|
||||||
|
file, invalid, symlink := prepareFiles(t)
|
||||||
|
|
||||||
|
before, err := os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
ts := []syscall.Timespec{{0, 0}, {0, 0}}
|
||||||
|
if err := LUtimesNano(symlink, ts); err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
symlinkInfo, err := os.Lstat(symlink)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if before.ModTime().Unix() == symlinkInfo.ModTime().Unix() {
|
||||||
|
t.Fatal("The modification time of the symlink should be different")
|
||||||
|
}
|
||||||
|
|
||||||
|
fileInfo, err := os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
if before.ModTime().Unix() != fileInfo.ModTime().Unix() {
|
||||||
|
t.Fatal("The modification time of the file should be same")
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := LUtimesNano(invalid, ts); err == nil {
|
||||||
|
t.Fatal("Doesn't return an error on a non-existing file")
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
// +build !linux
|
// +build !linux,!freebsd
|
||||||
|
|
||||||
package system
|
package system
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue