diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2006-06-15T11·56+0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2006-06-15T11·56+0000 |
commit | 588cb0eade0c14acdf4a20dfec5678715cc6542e (patch) | |
tree | f37d7546d85b9c262c2905aea42399c145a72943 /src/nix-env | |
parent | 49de87132f3f1685fcdd4157f89ca817647028b0 (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/nix-env')
-rw-r--r-- | src/nix-env/main.cc | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/nix-env/main.cc b/src/nix-env/main.cc index 560612825b31..0198aed575c9 100644 --- a/src/nix-env/main.cc +++ b/src/nix-env/main.cc @@ -10,6 +10,7 @@ #include "help.txt.hh" #include "nixexpr-ast.hh" #include "get-drvs.hh" +#include "pathlocks.hh" #include <cerrno> #include <ctime> @@ -411,6 +412,14 @@ static void printMissing(EvalState & state, const DrvInfos & elems) } +static void lockProfile(PathLocks & lock, const Path & profile) +{ + lock.lockPaths(singleton<PathSet>(profile), + (format("waiting for lock on profile `%1%'") % profile).str()); + lock.setDeletion(true); +} + + static void installDerivations(Globals & globals, const Strings & args, const Path & profile) { @@ -426,6 +435,8 @@ static void installDerivations(Globals & globals, /* Add in the already installed derivations, unless they have the same name as a to-be-installed element. */ + PathLocks lock; + lockProfile(lock, profile); DrvInfos installedElems = queryInstalled(globals.state, profile); DrvInfos allElems(newElems); @@ -480,6 +491,8 @@ static void upgradeDerivations(Globals & globals, name and a higher version number. */ /* Load the currently installed derivations. */ + PathLocks lock; + lockProfile(lock, profile); DrvInfos installedElems = queryInstalled(globals.state, profile); /* Fetch all derivations from the input file. */ @@ -559,6 +572,8 @@ static void opUpgrade(Globals & globals, static void uninstallDerivations(Globals & globals, DrvNames & selectors, Path & profile) { + PathLocks lock; + lockProfile(lock, profile); DrvInfos installedElems = queryInstalled(globals.state, profile); DrvInfos newElems; |