7e3b32fff8
Approved by: portmgr Approved by: bapt (mentor)
32 lines
1.5 KiB
Text
32 lines
1.5 KiB
Text
This is my first alpha release of File::Lock, my version of the code
|
|
greatfully provided by Jarrko. I've mucked about with it quite a bit,
|
|
and there are a few policy decisions you might not agree with:
|
|
|
|
All of the locking functions (see t/* for full details),
|
|
File::lock::(lockf/flock/fcntl) are not exported from File::Lock. They all
|
|
take the same set of arguments: FileHandle, mode, pos, whence, length.
|
|
(Except for lockf, which doesn't take the position arguments.) Mode is two
|
|
characters, and can be "wb" for write-lock/non-blocking, or "rn", for
|
|
read-lock/blocking. Most other characters will work fine. (Look in typemap)
|
|
pos, whence, and length default to "the whole file". Use "u" to unlock a
|
|
handle.
|
|
|
|
The only OO interface is via "new File::Lock()" which uses
|
|
File::Lock::fcntl. If it were working properly, then the lock would be
|
|
unlocked on destruction. But it isn't.
|
|
|
|
File::Lock::lockfile isn't written yet, but will be.
|
|
|
|
You can use a mode of "t" or "i" to get info/test a lock. fcntl in array
|
|
context will return an array consisting of all the usual fcntl data.
|
|
In any other case, a single letter is returned, "u", "w", or "r",
|
|
for the detected locking mode. (or unlocked.)
|
|
|
|
All calls return true if successful. Currently no mucking about with errno
|
|
is done, so it might not be the same for the same condition on all systems.
|
|
|
|
If you need real fcntl() and it's constants, use Fcntl. File::Lock does
|
|
optionally export SEEK_*, and LOCK_EX|UN|SH, though. (I don't remember why,
|
|
though, on the latter.)
|
|
|
|
Any comments, complaints, or bug patches would be greatly appreciated.
|