aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/syscall/syscall_windows.go6
-rw-r--r--src/syscall/syscall_windows_test.go30
2 files changed, 25 insertions, 11 deletions
diff --git a/src/syscall/syscall_windows.go b/src/syscall/syscall_windows.go
index db1f4f2ba4..67a71dfc76 100644
--- a/src/syscall/syscall_windows.go
+++ b/src/syscall/syscall_windows.go
@@ -362,8 +362,12 @@ func Open(name string, flag int, perm uint32) (fd Handle, err error) {
access |= GENERIC_WRITE
}
if flag&O_APPEND != 0 {
- access &^= GENERIC_WRITE
access |= FILE_APPEND_DATA
+ // Remove GENERIC_WRITE access unless O_TRUNC is set,
+ // in which case we need it to truncate the file.
+ if flag&O_TRUNC == 0 {
+ access &^= GENERIC_WRITE
+ }
}
sharemode := uint32(FILE_SHARE_READ | FILE_SHARE_WRITE)
var sa *SecurityAttributes
diff --git a/src/syscall/syscall_windows_test.go b/src/syscall/syscall_windows_test.go
index ea1e8c9b3c..8b5af9c501 100644
--- a/src/syscall/syscall_windows_test.go
+++ b/src/syscall/syscall_windows_test.go
@@ -15,29 +15,39 @@ import (
"testing"
)
-func TestOpen_Dir(t *testing.T) {
+func TestOpen(t *testing.T) {
t.Parallel()
dir := t.TempDir()
+ file := filepath.Join(dir, "a")
+ f, err := os.Create(file)
+ if err != nil {
+ t.Fatal(err)
+ }
+ f.Close()
+
tests := []struct {
+ path string
flag int
err error
}{
- {syscall.O_RDONLY, nil},
- {syscall.O_CREAT, nil},
- {syscall.O_RDONLY | syscall.O_CREAT, nil},
- {syscall.O_RDONLY | syscall.O_TRUNC, syscall.ERROR_ACCESS_DENIED},
- {syscall.O_WRONLY | syscall.O_RDWR, syscall.EISDIR},
- {syscall.O_WRONLY, syscall.EISDIR},
- {syscall.O_RDWR, syscall.EISDIR},
+ {dir, syscall.O_RDONLY, nil},
+ {dir, syscall.O_CREAT, nil},
+ {dir, syscall.O_RDONLY | syscall.O_CREAT, nil},
+ {file, syscall.O_APPEND | syscall.O_WRONLY | os.O_CREATE, nil},
+ {file, syscall.O_APPEND | syscall.O_WRONLY | os.O_CREATE | os.O_TRUNC, nil},
+ {dir, syscall.O_RDONLY | syscall.O_TRUNC, syscall.ERROR_ACCESS_DENIED},
+ {dir, syscall.O_WRONLY | syscall.O_RDWR, syscall.EISDIR},
+ {dir, syscall.O_WRONLY, syscall.EISDIR},
+ {dir, syscall.O_RDWR, syscall.EISDIR},
}
for i, tt := range tests {
- h, err := syscall.Open(dir, tt.flag, 0)
+ h, err := syscall.Open(tt.path, tt.flag, 0o660)
if err == nil {
syscall.CloseHandle(h)
}
if err != tt.err {
- t.Errorf("%d: Open got %v, want %v", i, err, tt.err)
+ t.Errorf("%d: Open got %q, want %q", i, err, tt.err)
}
}
}