aboutsummaryrefslogtreecommitdiff
path: root/src/libstore
diff options
context:
space:
mode:
authorEelco Dolstra <e.dolstra@tudelft.nl>2006-06-15 11:56:49 +0000
committerEelco Dolstra <e.dolstra@tudelft.nl>2006-06-15 11:56:49 +0000
commit588cb0eade0c14acdf4a20dfec5678715cc6542e (patch)
treef37d7546d85b9c262c2905aea42399c145a72943 /src/libstore
parent49de87132f3f1685fcdd4157f89ca817647028b0 (diff)
* In `nix-env -i|-u|-e', lock the profile to prevent races between
concurrent nix-env operations on the same profile. Fixes NIX-7.
Diffstat (limited to 'src/libstore')
-rw-r--r--src/libstore/pathlocks.cc11
-rw-r--r--src/libstore/pathlocks.hh6
2 files changed, 11 insertions, 6 deletions
diff --git a/src/libstore/pathlocks.cc b/src/libstore/pathlocks.cc
index 3beb49aac..7f7cbdf15 100644
--- a/src/libstore/pathlocks.cc
+++ b/src/libstore/pathlocks.cc
@@ -51,14 +51,14 @@ PathLocks::PathLocks()
}
-PathLocks::PathLocks(const PathSet & paths)
+PathLocks::PathLocks(const PathSet & paths, const string & waitMsg)
: deletePaths(false)
{
- lockPaths(paths);
+ lockPaths(paths, waitMsg);
}
-void PathLocks::lockPaths(const PathSet & _paths)
+void PathLocks::lockPaths(const PathSet & _paths, const string & waitMsg)
{
/* May be called only once! */
assert(fds.empty());
@@ -94,7 +94,10 @@ void PathLocks::lockPaths(const PathSet & _paths)
throw SysError(format("opening lock file `%1%'") % lockPath);
/* Acquire an exclusive lock. */
- lockFile(fd, ltWrite, true);
+ if (!lockFile(fd, ltWrite, false)) {
+ if (waitMsg != "") printMsg(lvlError, waitMsg);
+ lockFile(fd, ltWrite, true);
+ }
debug(format("lock acquired on `%1%'") % lockPath);
diff --git a/src/libstore/pathlocks.hh b/src/libstore/pathlocks.hh
index 42ebe58df..2fd0e0d1e 100644
--- a/src/libstore/pathlocks.hh
+++ b/src/libstore/pathlocks.hh
@@ -18,8 +18,10 @@ private:
public:
PathLocks();
- PathLocks(const PathSet & paths);
- void lockPaths(const PathSet & _paths);
+ PathLocks(const PathSet & paths,
+ const string & waitMsg = "");
+ void lockPaths(const PathSet & _paths,
+ const string & waitMsg = "");
~PathLocks();
void setDeletion(bool deletePaths);
};