aboutsummaryrefslogtreecommitdiff
path: root/src/libexpr/primops.cc
diff options
context:
space:
mode:
authorEelco Dolstra <e.dolstra@tudelft.nl>2006-03-09 15:09:18 +0000
committerEelco Dolstra <e.dolstra@tudelft.nl>2006-03-09 15:09:18 +0000
commit922697c8b27570b6c76a472266507b73f6b79f7f (patch)
treef9e189f6bbc77d036f4ee6c091561710d85cc389 /src/libexpr/primops.cc
parent6dca5c9099b92b6a93071197aa606a31ccd83a37 (diff)
* Big speedup (factor > 2.5) in all nix-env operations that do actual
instantiation, e.g. "nix-env -i" and "nix-env -qas" (but not "nix-env -qa"). It turns out that many redundant calls to addToStore(path) were made, which reads and hashes the entire path. For instance, the bash bootstrap binary in Nixpkgs would be read and hashed many times. As a result nix-env would spend around 92% of its time in the function sha256_block (according to callgrind). Some simple memoization fixes this.
Diffstat (limited to 'src/libexpr/primops.cc')
-rw-r--r--src/libexpr/primops.cc12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/libexpr/primops.cc b/src/libexpr/primops.cc
index 31fff0b49..77721a5a8 100644
--- a/src/libexpr/primops.cc
+++ b/src/libexpr/primops.cc
@@ -165,9 +165,15 @@ static void processBinding(EvalState & state, Expr e, Derivation & drv,
if (isDerivation(srcPath))
throw Error(format("file names are not allowed to end in `%1%'")
% drvExtension);
- Path dstPath(addToStore(srcPath));
- printMsg(lvlChatty, format("copied source `%1%' -> `%2%'")
- % srcPath % dstPath);
+ Path dstPath;
+ if (state.srcToStore[srcPath] != "")
+ dstPath = state.srcToStore[srcPath];
+ else {
+ dstPath = addToStore(srcPath);
+ state.srcToStore[srcPath] = dstPath;
+ printMsg(lvlChatty, format("copied source `%1%' -> `%2%'")
+ % srcPath % dstPath);
+ }
drv.inputSrcs.insert(dstPath);
ss.push_back(dstPath);
}