diff options
author | Felix Fietkau <nbd@openwrt.org> | 2015-09-09 20:36:10 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2015-09-09 20:36:10 +0000 |
commit | 29c44e0647b4ab908ffbad58a9a850038c12920a (patch) | |
tree | 7c5368c9d79993f208eda78d8f55f360ae45e0ba /package/utils | |
parent | b07a54e686aa61e7288583d54eb38cbf40880493 (diff) | |
download | master-187ad058-29c44e0647b4ab908ffbad58a9a850038c12920a.tar.gz master-187ad058-29c44e0647b4ab908ffbad58a9a850038c12920a.tar.bz2 master-187ad058-29c44e0647b4ab908ffbad58a9a850038c12920a.zip |
busybox: lock: implement -n "Fail rather than wait"
lock -n is similiar to flock -n. If the lock was already taken,
fail with exit code = 1 and write error message to stderr.
example:
if ! lock -n /tmp/foo ; then
echo lock exits.
else
echo lock was free. But is locked now.
fi
> lock was free. But is locked now.
> lock exists.
Signed-off-by: Alexander Couzens <lynxis@fe80.eu>
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@46836 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/utils')
-rw-r--r-- | package/utils/busybox/patches/220-add_lock_util.patch | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/package/utils/busybox/patches/220-add_lock_util.patch b/package/utils/busybox/patches/220-add_lock_util.patch index 5c7ca26da8..9cac9e6219 100644 --- a/package/utils/busybox/patches/220-add_lock_util.patch +++ b/package/utils/busybox/patches/220-add_lock_util.patch @@ -35,7 +35,7 @@ lib-$(CONFIG_MICROCOM) += microcom.o --- /dev/null +++ b/miscutils/lock.c -@@ -0,0 +1,135 @@ +@@ -0,0 +1,144 @@ +/* + * Copyright (C) 2006 Felix Fietkau <nbd@openwrt.org> + * @@ -56,6 +56,7 @@ +static int unlock = 0; +static int shared = 0; +static int waitonly = 0; ++static int try_lock = 0; +static int fd; +static char *file; + @@ -65,6 +66,7 @@ + " -s Use shared locking\n" + " -u Unlock\n" + " -w Wait for the lock to become free, don't acquire lock\n" ++ " -n Don't wait for the lock to become free. Fail with exit code\n" + "\n", name); + exit(1); +} @@ -95,6 +97,7 @@ +static int do_lock(void) +{ + int pid; ++ int flags; + char pidstr[8]; + + if ((fd = open(file, O_RDWR | O_CREAT | O_EXCL, 0700)) < 0) { @@ -104,7 +107,10 @@ + } + } + -+ if (flock(fd, (shared ? LOCK_SH : LOCK_EX)) < 0) { ++ flags = shared ? LOCK_SH : LOCK_EX; ++ flags |= try_lock ? LOCK_NB : 0; ++ ++ if (flock(fd, flags) < 0) { + fprintf(stderr, "Can't lock %s\n", file); + return 1; + } @@ -156,6 +162,9 @@ + case 'u': + unlock = 1; + break; ++ case 'n': ++ try_lock = 1; ++ break; + } + } + c--; |