2003-08-01 17:11:19 +03:00
|
|
|
#ifndef __PATHLOCKS_H
|
|
|
|
#define __PATHLOCKS_H
|
|
|
|
|
2006-09-05 00:06:23 +03:00
|
|
|
#include "types.hh"
|
|
|
|
|
|
|
|
|
|
|
|
namespace nix {
|
2003-08-01 17:11:19 +03:00
|
|
|
|
|
|
|
|
2006-06-20 20:48:10 +03: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 18:33:00 +03:00
|
|
|
typedef enum LockType { ltRead, ltWrite, ltNone };
|
|
|
|
|
|
|
|
bool lockFile(int fd, LockType lockType, bool wait);
|
|
|
|
|
|
|
|
|
2003-08-01 17:11:19 +03:00
|
|
|
class PathLocks
|
|
|
|
{
|
|
|
|
private:
|
2006-09-05 00:06:23 +03:00
|
|
|
typedef std::pair<int, Path> FDPair;
|
2005-01-27 14:19:25 +02:00
|
|
|
list<FDPair> fds;
|
2003-11-21 18:05:19 +02:00
|
|
|
bool deletePaths;
|
2003-08-01 17:11:19 +03:00
|
|
|
|
|
|
|
public:
|
2004-05-11 21:05:44 +03:00
|
|
|
PathLocks();
|
2006-06-15 14:56:49 +03:00
|
|
|
PathLocks(const PathSet & paths,
|
|
|
|
const string & waitMsg = "");
|
|
|
|
void lockPaths(const PathSet & _paths,
|
|
|
|
const string & waitMsg = "");
|
2003-08-01 17:11:19 +03:00
|
|
|
~PathLocks();
|
2003-11-21 18:05:19 +02:00
|
|
|
void setDeletion(bool deletePaths);
|
2003-08-01 17:11:19 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2007-08-28 14:36:17 +03:00
|
|
|
bool pathIsLockedByMe(const Path & path);
|
|
|
|
|
|
|
|
|
2006-09-05 00:06:23 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2003-08-01 17:11:19 +03:00
|
|
|
#endif /* !__PATHLOCKS_H */
|