buildkit/vendor/github.com/gofrs/flock
Tibor Vass ad8b35e3d4 Migrate from vndr to go mod
go get -u github.com/tiborvass/gomod
  GO111MODULE=on gomod init
  GO111MODULE=on go mod tidy
  GO111MODULE=on go mod vendor

Signed-off-by: Tibor Vass <tibor@docker.com>
2019-01-31 22:44:47 +00:00
..
.gitignore Migrate from vndr to go mod 2019-01-31 22:44:47 +00:00
.travis.yml Migrate from vndr to go mod 2019-01-31 22:44:47 +00:00
LICENSE support local cache exporter and importer 2019-01-19 02:38:26 +09:00
README.md support local cache exporter and importer 2019-01-19 02:38:26 +09:00
appveyor.yml Migrate from vndr to go mod 2019-01-31 22:44:47 +00:00
flock.go support local cache exporter and importer 2019-01-19 02:38:26 +09:00
flock_unix.go support local cache exporter and importer 2019-01-19 02:38:26 +09:00
flock_winapi.go support local cache exporter and importer 2019-01-19 02:38:26 +09:00
flock_windows.go support local cache exporter and importer 2019-01-19 02:38:26 +09:00

README.md

flock

TravisCI Build Status GoDoc License

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.