You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
f451b455c4
Signed-off-by: CrazyMax <crazy-max@users.noreply.github.com> |
2 years ago | |
---|---|---|
.. | ||
.gitignore | 6 years ago | |
.travis.yml | 2 years ago | |
LICENSE | 4 years ago | |
README.md | 4 years ago | |
appveyor.yml | 2 years ago | |
flock.go | 2 years ago | |
flock_aix.go | 2 years ago | |
flock_unix.go | 2 years ago | |
flock_winapi.go | 6 years ago | |
flock_windows.go | 4 years ago |
README.md
flock
flock
implements a thread-safe sync.Locker interface for file locking. It also
includes a non-blocking TryLock() function to allow locking without blocking execution.
License
flock
is released under the BSD 3-Clause License. See the LICENSE
file for more details.
Go Compatibility
This package makes use of the context
package that was introduced in Go 1.7. As such, this
package has an implicit dependency on Go 1.7+.
Installation
go get -u github.com/gofrs/flock
Usage
import "github.com/gofrs/flock"
fileLock := flock.New("/var/lock/go-lock.lock")
locked, err := fileLock.TryLock()
if err != nil {
// handle locking error
}
if locked {
// do work
fileLock.Unlock()
}
For more detailed usage information take a look at the package API docs on GoDoc.