if e == nil {
return r, nil
}
- r, e = openFile(name, flag|syscall.O_CLOEXEC, perm)
+ r, e = openFile(name, flag, perm)
if e == nil {
return r, nil
}
fi.Mode = 0
if stat.Windata.FileAttributes == syscall.FILE_ATTRIBUTE_DIRECTORY {
fi.Mode = fi.Mode | syscall.S_IFDIR
- }
- if stat.Windata.FileAttributes == syscall.FILE_ATTRIBUTE_NORMAL {
+ } else {
fi.Mode = fi.Mode | syscall.S_IFREG
}
if stat.Windata.FileAttributes == syscall.FILE_ATTRIBUTE_READONLY {
if len(path) == 0 {
return -1, ERROR_FILE_NOT_FOUND
}
- var access, sharemode uint32
- switch {
- case mode&O_CREAT != 0:
- access = GENERIC_READ | GENERIC_WRITE
- sharemode = 0
- case mode&O_RDWR == O_RDONLY:
+ var access uint32
+ switch mode & (O_RDONLY | O_WRONLY | O_RDWR) {
+ case O_RDONLY:
access = GENERIC_READ
- sharemode = FILE_SHARE_READ
- case mode&O_RDWR == O_WRONLY:
+ case O_WRONLY:
access = GENERIC_WRITE
- sharemode = FILE_SHARE_READ
- case mode&O_RDWR == O_RDWR:
+ case O_RDWR:
access = GENERIC_READ | GENERIC_WRITE
- sharemode = FILE_SHARE_READ | FILE_SHARE_WRITE
}
+ if mode&O_CREAT != 0 {
+ access |= GENERIC_WRITE
+ }
+ sharemode := uint32(FILE_SHARE_READ | FILE_SHARE_WRITE)
var createmode uint32
switch {
case mode&O_CREAT != 0: