2003-08-01 14:11:19 +00:00
|
|
|
#ifndef __PATHLOCKS_H
|
|
|
|
#define __PATHLOCKS_H
|
|
|
|
|
|
|
|
#include "util.hh"
|
|
|
|
|
|
|
|
|
2006-06-20 17:48:10 +00:00
|
|
|
/* Open (possibly create) a lock file and return the file descriptor.
|
|
|
|
-1 is returned if create is false and the lock could not be opened
|
|
|
|
because it doesn't exist. Any other error throws an exception. */
|
|
|
|
int openLockFile(const Path & path, bool create);
|
|
|
|
|
|
|
|
/* Delete an open lock file. Both must be called to be fully portable
|
|
|
|
between Unix and Windows. */
|
|
|
|
void deleteLockFilePreClose(const Path & path, int fd);
|
|
|
|
void deleteLockFilePostClose(const Path & path);
|
|
|
|
|
2003-10-14 15:33:00 +00:00
|
|
|
typedef enum LockType { ltRead, ltWrite, ltNone };
|
|
|
|
|
|
|
|
bool lockFile(int fd, LockType lockType, bool wait);
|
|
|
|
|
|
|
|
|
2003-08-01 14:11:19 +00:00
|
|
|
class PathLocks
|
|
|
|
{
|
|
|
|
private:
|
2005-01-27 12:19:25 +00:00
|
|
|
typedef pair<int, Path> FDPair;
|
|
|
|
list<FDPair> fds;
|
2003-11-21 16:05:19 +00:00
|
|
|
bool deletePaths;
|
2003-08-01 14:11:19 +00:00
|
|
|
|
|
|
|
public:
|
2004-05-11 18:05:44 +00:00
|
|
|
PathLocks();
|
2006-06-15 11:56:49 +00:00
|
|
|
PathLocks(const PathSet & paths,
|
|
|
|
const string & waitMsg = "");
|
|
|
|
void lockPaths(const PathSet & _paths,
|
|
|
|
const string & waitMsg = "");
|
2003-08-01 14:11:19 +00:00
|
|
|
~PathLocks();
|
2003-11-21 16:05:19 +00:00
|
|
|
void setDeletion(bool deletePaths);
|
2003-08-01 14:11:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif /* !__PATHLOCKS_H */
|