Merge pull request #16490 from Microsoft/10662-mtimefix
Fixed file modified time not changing on windows
This commit is contained in:
commit
911628c5ae
14 changed files with 401 additions and 32 deletions
|
@ -375,19 +375,19 @@ func createTarFile(path, extractDir string, hdr *tar.Header, reader io.Reader, L
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
ts := []syscall.Timespec{timeToTimespec(hdr.AccessTime), timeToTimespec(hdr.ModTime)}
|
// system.Chtimes doesn't support a NOFOLLOW flag atm
|
||||||
// syscall.UtimesNano doesn't support a NOFOLLOW flag atm
|
|
||||||
if hdr.Typeflag == tar.TypeLink {
|
if hdr.Typeflag == tar.TypeLink {
|
||||||
if fi, err := os.Lstat(hdr.Linkname); err == nil && (fi.Mode()&os.ModeSymlink == 0) {
|
if fi, err := os.Lstat(hdr.Linkname); err == nil && (fi.Mode()&os.ModeSymlink == 0) {
|
||||||
if err := system.UtimesNano(path, ts); err != nil && err != system.ErrNotSupportedPlatform {
|
if err := system.Chtimes(path, hdr.AccessTime, hdr.ModTime); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if hdr.Typeflag != tar.TypeSymlink {
|
} else if hdr.Typeflag != tar.TypeSymlink {
|
||||||
if err := system.UtimesNano(path, ts); err != nil && err != system.ErrNotSupportedPlatform {
|
if err := system.Chtimes(path, hdr.AccessTime, hdr.ModTime); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
ts := []syscall.Timespec{timeToTimespec(hdr.AccessTime), timeToTimespec(hdr.ModTime)}
|
||||||
if err := system.LUtimesNano(path, ts); err != nil && err != system.ErrNotSupportedPlatform {
|
if err := system.LUtimesNano(path, ts); err != nil && err != system.ErrNotSupportedPlatform {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
@ -644,8 +644,8 @@ loop:
|
||||||
|
|
||||||
for _, hdr := range dirs {
|
for _, hdr := range dirs {
|
||||||
path := filepath.Join(dest, hdr.Name)
|
path := filepath.Join(dest, hdr.Name)
|
||||||
ts := []syscall.Timespec{timeToTimespec(hdr.AccessTime), timeToTimespec(hdr.ModTime)}
|
|
||||||
if err := syscall.UtimesNano(path, ts); err != nil {
|
if err := system.Chtimes(path, hdr.AccessTime, hdr.ModTime); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,6 @@ import (
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
"runtime"
|
"runtime"
|
||||||
"strings"
|
"strings"
|
||||||
"syscall"
|
|
||||||
|
|
||||||
"github.com/Sirupsen/logrus"
|
"github.com/Sirupsen/logrus"
|
||||||
"github.com/docker/docker/pkg/pools"
|
"github.com/docker/docker/pkg/pools"
|
||||||
|
@ -184,8 +183,7 @@ func UnpackLayer(dest string, layer Reader) (size int64, err error) {
|
||||||
|
|
||||||
for _, hdr := range dirs {
|
for _, hdr := range dirs {
|
||||||
path := filepath.Join(dest, hdr.Name)
|
path := filepath.Join(dest, hdr.Name)
|
||||||
ts := []syscall.Timespec{timeToTimespec(hdr.AccessTime), timeToTimespec(hdr.ModTime)}
|
if err := system.Chtimes(path, hdr.AccessTime, hdr.ModTime); err != nil {
|
||||||
if err := syscall.UtimesNano(path, ts); err != nil {
|
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
31
system/chtimes.go
Normal file
31
system/chtimes.go
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// Chtimes changes the access time and modified time of a file at the given path
|
||||||
|
func Chtimes(name string, atime time.Time, mtime time.Time) error {
|
||||||
|
unixMinTime := time.Unix(0, 0)
|
||||||
|
// The max Unix time is 33 bits set
|
||||||
|
unixMaxTime := unixMinTime.Add((1<<33 - 1) * time.Second)
|
||||||
|
|
||||||
|
// If the modified time is prior to the Unix Epoch, or after the
|
||||||
|
// end of Unix Time, os.Chtimes has undefined behavior
|
||||||
|
// default to Unix Epoch in this case, just in case
|
||||||
|
|
||||||
|
if atime.Before(unixMinTime) || atime.After(unixMaxTime) {
|
||||||
|
atime = unixMinTime
|
||||||
|
}
|
||||||
|
|
||||||
|
if mtime.Before(unixMinTime) || mtime.After(unixMaxTime) {
|
||||||
|
mtime = unixMinTime
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := os.Chtimes(name, atime, mtime); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
120
system/chtimes_test.go
Normal file
120
system/chtimes_test.go
Normal file
|
@ -0,0 +1,120 @@
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"io/ioutil"
|
||||||
|
"os"
|
||||||
|
"path/filepath"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// prepareTempFile creates a temporary file in a temporary directory.
|
||||||
|
func prepareTempFile(t *testing.T) (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)
|
||||||
|
}
|
||||||
|
return file, dir
|
||||||
|
}
|
||||||
|
|
||||||
|
// TestChtimes tests Chtimes on a tempfile. Test only mTime, because aTime is OS dependent
|
||||||
|
func TestChtimes(t *testing.T) {
|
||||||
|
file, dir := prepareTempFile(t)
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
|
beforeUnixEpochTime := time.Unix(0, 0).Add(-100 * time.Second)
|
||||||
|
unixEpochTime := time.Unix(0, 0)
|
||||||
|
afterUnixEpochTime := time.Unix(100, 0)
|
||||||
|
// The max Unix time is 33 bits set
|
||||||
|
unixMaxTime := unixEpochTime.Add((1<<33 - 1) * time.Second)
|
||||||
|
afterUnixMaxTime := unixMaxTime.Add(100 * time.Second)
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to Unix Epoch
|
||||||
|
Chtimes(file, unixEpochTime, unixEpochTime)
|
||||||
|
|
||||||
|
f, err := os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, f.ModTime())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime before Unix Epoch and mTime set to Unix Epoch
|
||||||
|
Chtimes(file, beforeUnixEpochTime, unixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, f.ModTime())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime set to Unix Epoch and mTime before Unix Epoch
|
||||||
|
Chtimes(file, unixEpochTime, beforeUnixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, f.ModTime())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to after Unix Epoch (valid time)
|
||||||
|
Chtimes(file, afterUnixEpochTime, afterUnixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != afterUnixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", afterUnixEpochTime, f.ModTime())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to Unix max time
|
||||||
|
Chtimes(file, unixMaxTime, unixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != unixMaxTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixMaxTime, f.ModTime())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime after Unix max time and mTime set to Unix max time
|
||||||
|
Chtimes(file, afterUnixMaxTime, unixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != unixMaxTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixMaxTime, f.ModTime())
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime set to Unix Epoch and mTime before Unix Epoch
|
||||||
|
Chtimes(file, unixMaxTime, afterUnixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if f.ModTime() != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, f.ModTime())
|
||||||
|
}
|
||||||
|
}
|
121
system/chtimes_unix_test.go
Normal file
121
system/chtimes_unix_test.go
Normal file
|
@ -0,0 +1,121 @@
|
||||||
|
// +build linux freebsd
|
||||||
|
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"syscall"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// TestChtimes tests Chtimes access time on a tempfile on Linux
|
||||||
|
func TestChtimesLinux(t *testing.T) {
|
||||||
|
file, dir := prepareTempFile(t)
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
|
beforeUnixEpochTime := time.Unix(0, 0).Add(-100 * time.Second)
|
||||||
|
unixEpochTime := time.Unix(0, 0)
|
||||||
|
afterUnixEpochTime := time.Unix(100, 0)
|
||||||
|
// The max Unix time is 33 bits set
|
||||||
|
unixMaxTime := unixEpochTime.Add((1<<33 - 1) * time.Second)
|
||||||
|
afterUnixMaxTime := unixMaxTime.Add(100 * time.Second)
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to Unix Epoch
|
||||||
|
Chtimes(file, unixEpochTime, unixEpochTime)
|
||||||
|
|
||||||
|
f, err := os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat := f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime := time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime before Unix Epoch and mTime set to Unix Epoch
|
||||||
|
Chtimes(file, beforeUnixEpochTime, unixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat = f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime set to Unix Epoch and mTime before Unix Epoch
|
||||||
|
Chtimes(file, unixEpochTime, beforeUnixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat = f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to after Unix Epoch (valid time)
|
||||||
|
Chtimes(file, afterUnixEpochTime, afterUnixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat = f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != afterUnixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", afterUnixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to Unix max time
|
||||||
|
Chtimes(file, unixMaxTime, unixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat = f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != unixMaxTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixMaxTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime after Unix max time and mTime set to Unix max time
|
||||||
|
Chtimes(file, afterUnixMaxTime, unixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat = f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime set to Unix Epoch and mTime before Unix Epoch
|
||||||
|
Chtimes(file, unixMaxTime, afterUnixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
stat = f.Sys().(*syscall.Stat_t)
|
||||||
|
aTime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||||
|
if aTime != unixMaxTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixMaxTime, aTime)
|
||||||
|
}
|
||||||
|
}
|
114
system/chtimes_windows_test.go
Normal file
114
system/chtimes_windows_test.go
Normal file
|
@ -0,0 +1,114 @@
|
||||||
|
// +build windows
|
||||||
|
|
||||||
|
package system
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"syscall"
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
// TestChtimes tests Chtimes access time on a tempfile on Windows
|
||||||
|
func TestChtimesWindows(t *testing.T) {
|
||||||
|
file, dir := prepareTempFile(t)
|
||||||
|
defer os.RemoveAll(dir)
|
||||||
|
|
||||||
|
beforeUnixEpochTime := time.Unix(0, 0).Add(-100 * time.Second)
|
||||||
|
unixEpochTime := time.Unix(0, 0)
|
||||||
|
afterUnixEpochTime := time.Unix(100, 0)
|
||||||
|
// The max Unix time is 33 bits set
|
||||||
|
unixMaxTime := unixEpochTime.Add((1<<33 - 1) * time.Second)
|
||||||
|
afterUnixMaxTime := unixMaxTime.Add(100 * time.Second)
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to Unix Epoch
|
||||||
|
Chtimes(file, unixEpochTime, unixEpochTime)
|
||||||
|
|
||||||
|
f, err := os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime := time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime before Unix Epoch and mTime set to Unix Epoch
|
||||||
|
Chtimes(file, beforeUnixEpochTime, unixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime = time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime set to Unix Epoch and mTime before Unix Epoch
|
||||||
|
Chtimes(file, unixEpochTime, beforeUnixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime = time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to after Unix Epoch (valid time)
|
||||||
|
Chtimes(file, afterUnixEpochTime, afterUnixEpochTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime = time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != afterUnixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", afterUnixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test both aTime and mTime set to Unix max time
|
||||||
|
Chtimes(file, unixMaxTime, unixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime = time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != unixMaxTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixMaxTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime after Unix max time and mTime set to Unix max time
|
||||||
|
Chtimes(file, afterUnixMaxTime, unixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime = time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != unixEpochTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixEpochTime, aTime)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test aTime set to Unix Epoch and mTime before Unix Epoch
|
||||||
|
Chtimes(file, unixMaxTime, afterUnixMaxTime)
|
||||||
|
|
||||||
|
f, err = os.Stat(file)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
aTime = time.Unix(0, f.Sys().(*syscall.Win32FileAttributeData).LastAccessTime.Nanoseconds())
|
||||||
|
if aTime != unixMaxTime {
|
||||||
|
t.Fatalf("Expected: %s, got: %s", unixMaxTime, aTime)
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,3 +1,5 @@
|
||||||
|
// +build linux freebsd
|
||||||
|
|
||||||
package system
|
package system
|
||||||
|
|
||||||
import (
|
import (
|
|
@ -1,3 +1,5 @@
|
||||||
|
// +build linux freebsd
|
||||||
|
|
||||||
package system
|
package system
|
||||||
|
|
||||||
import (
|
import (
|
|
@ -1,3 +1,5 @@
|
||||||
|
// +build linux freebsd
|
||||||
|
|
||||||
package system
|
package system
|
||||||
|
|
||||||
import (
|
import (
|
|
@ -6,9 +6,3 @@ import "syscall"
|
||||||
func LUtimesNano(path string, ts []syscall.Timespec) error {
|
func LUtimesNano(path string, ts []syscall.Timespec) error {
|
||||||
return ErrNotSupportedPlatform
|
return ErrNotSupportedPlatform
|
||||||
}
|
}
|
||||||
|
|
||||||
// UtimesNano is used to change access and modification time of path.
|
|
||||||
// it can't be used for symbol link file.
|
|
||||||
func UtimesNano(path string, ts []syscall.Timespec) error {
|
|
||||||
return syscall.UtimesNano(path, ts)
|
|
||||||
}
|
|
||||||
|
|
|
@ -20,9 +20,3 @@ func LUtimesNano(path string, ts []syscall.Timespec) error {
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// UtimesNano is used to change access and modification time of the specified path.
|
|
||||||
// It can't be used for symbol link file.
|
|
||||||
func UtimesNano(path string, ts []syscall.Timespec) error {
|
|
||||||
return syscall.UtimesNano(path, ts)
|
|
||||||
}
|
|
||||||
|
|
|
@ -24,9 +24,3 @@ func LUtimesNano(path string, ts []syscall.Timespec) error {
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// UtimesNano is used to change access and modification time of the specified path.
|
|
||||||
// It can't be used for symbol link file.
|
|
||||||
func UtimesNano(path string, ts []syscall.Timespec) error {
|
|
||||||
return syscall.UtimesNano(path, ts)
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,3 +1,5 @@
|
||||||
|
// +build linux freebsd
|
||||||
|
|
||||||
package system
|
package system
|
||||||
|
|
||||||
import (
|
import (
|
|
@ -8,8 +8,3 @@ import "syscall"
|
||||||
func LUtimesNano(path string, ts []syscall.Timespec) error {
|
func LUtimesNano(path string, ts []syscall.Timespec) error {
|
||||||
return ErrNotSupportedPlatform
|
return ErrNotSupportedPlatform
|
||||||
}
|
}
|
||||||
|
|
||||||
// UtimesNano is not supported on platforms other than linux, freebsd and darwin.
|
|
||||||
func UtimesNano(path string, ts []syscall.Timespec) error {
|
|
||||||
return ErrNotSupportedPlatform
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue