Mercurial > hg > audiodb
view lock.cpp @ 663:bcc7a6ddb2c8
Better treatment of refine.hopsize
Only adapt the query loop hopping if ADB_REFINE_HOP_SIZE is actually on the
refine flags, rather than blithely taking the value of refine.hopsize.
Significantly reduces the chances of inadvertently causing an infinite loop.
Adjust the tests to remove the 23 now useless instances of
"refine.hopsize = 1;"
Closes trac ticket #16
author | mas01cr |
---|---|
date | Thu, 28 Jan 2010 10:23:42 +0000 |
parents | 4eedc18634f5 |
children |
line wrap: on
line source
extern "C" { #include "audioDB_API.h" } #include "audioDB-internals.h" int acquire_lock(int fd, bool exclusive) { #if !defined(WIN32) struct flock lock; int status; lock.l_type = exclusive ? F_WRLCK : F_RDLCK; lock.l_whence = SEEK_SET; lock.l_start = 0; lock.l_len = ADB_HEADER_SIZE; retry: do { status = fcntl(fd, F_SETLKW, &lock); } while (status != 0 && errno == EINTR); if (status) { if (errno == EAGAIN) { sleep(1); goto retry; } else { return status; } } return 0; #else /* _locking() only supports exclusive locks */ int status; retry: status = _locking(fd, _LK_NBLCK, ADB_HEADER_SIZE); if(status) { Sleep(1000); goto retry; } return 0; #endif } int divest_lock(int fd) { #if !defined(WIN32) struct flock lock; lock.l_type = F_UNLCK; lock.l_whence = SEEK_SET; lock.l_start = 0; lock.l_len = ADB_HEADER_SIZE; return fcntl(fd, F_SETLKW, &lock); #else return _locking(fd, _LK_UNLCK, ADB_HEADER_SIZE); #endif }