mirror of
https://gitea.com/gitea/tea.git
synced 2024-11-23 02:51:37 +01:00
6cff3b1cc7
Merge branch 'master' into vendor-migrate-go-git Merge branch 'master' into vendor-migrate-go-git migrate src-d/go-git -> go-git/go-git Co-authored-by: 6543 <6543@obermui.de> Reviewed-on: https://gitea.com/gitea/tea/pulls/128 Reviewed-by: techknowlogick <techknowlogick@gitea.io> Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
62 lines
1.1 KiB
Go
62 lines
1.1 KiB
Go
// +build windows
|
|
|
|
package osfs
|
|
|
|
import (
|
|
"os"
|
|
"runtime"
|
|
"unsafe"
|
|
|
|
"golang.org/x/sys/windows"
|
|
)
|
|
|
|
type fileInfo struct {
|
|
os.FileInfo
|
|
name string
|
|
}
|
|
|
|
func (fi *fileInfo) Name() string {
|
|
return fi.name
|
|
}
|
|
|
|
var (
|
|
kernel32DLL = windows.NewLazySystemDLL("kernel32.dll")
|
|
lockFileExProc = kernel32DLL.NewProc("LockFileEx")
|
|
unlockFileProc = kernel32DLL.NewProc("UnlockFile")
|
|
)
|
|
|
|
const (
|
|
lockfileExclusiveLock = 0x2
|
|
)
|
|
|
|
func (f *file) Lock() error {
|
|
f.m.Lock()
|
|
defer f.m.Unlock()
|
|
|
|
var overlapped windows.Overlapped
|
|
// err is always non-nil as per sys/windows semantics.
|
|
ret, _, err := lockFileExProc.Call(f.File.Fd(), lockfileExclusiveLock, 0, 0xFFFFFFFF, 0,
|
|
uintptr(unsafe.Pointer(&overlapped)))
|
|
runtime.KeepAlive(&overlapped)
|
|
if ret == 0 {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (f *file) Unlock() error {
|
|
f.m.Lock()
|
|
defer f.m.Unlock()
|
|
|
|
// err is always non-nil as per sys/windows semantics.
|
|
ret, _, err := unlockFileProc.Call(f.File.Fd(), 0, 0, 0xFFFFFFFF, 0)
|
|
if ret == 0 {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func rename(from, to string) error {
|
|
return os.Rename(from, to)
|
|
}
|