aboutsummaryrefslogtreecommitdiff
path: root/src/libstore/store-api.cc
diff options
context:
space:
mode:
authorEelco Dolstra <edolstra@gmail.com>2017-02-07 20:47:45 +0100
committerEelco Dolstra <edolstra@gmail.com>2017-02-07 20:47:45 +0100
commit6f4682ad36c97355fbb7ba86a9ce265c22102055 (patch)
tree99b5fcd1f04f3ab95852e7ffea379b9bfbceeae8 /src/libstore/store-api.cc
parentcaa5793b4a74049ee37dd88eb1c5b785456ce40d (diff)
parentbfa41eb6714a7e7c3956389ee063e898bd1f37ff (diff)
Merge branch 'nix-copy-closure-c++' of https://github.com/shlevy/nix
Diffstat (limited to 'src/libstore/store-api.cc')
-rw-r--r--src/libstore/store-api.cc24
1 files changed, 22 insertions, 2 deletions
diff --git a/src/libstore/store-api.cc b/src/libstore/store-api.cc
index 11c2f4b02..b5934a0d1 100644
--- a/src/libstore/store-api.cc
+++ b/src/libstore/store-api.cc
@@ -5,6 +5,7 @@
#include "nar-info-disk-cache.hh"
#include "thread-pool.hh"
#include "json.hh"
+#include "derivations.hh"
#include <future>
@@ -780,8 +781,27 @@ std::list<ref<Store>> getDefaultSubstituters()
}
-void copyPaths(ref<Store> from, ref<Store> to, const Paths & storePaths)
-{
+void copyPaths(ref<Store> from, ref<Store> to, const Paths & storePaths, bool substitute)
+{
+ if (substitute) {
+ /* Filter out .drv files (we don't want to build anything). */
+ PathSet paths2;
+ for (auto & path : storePaths)
+ if (!isDerivation(path)) paths2.insert(path);
+ unsigned long long downloadSize, narSize;
+ PathSet willBuild, willSubstitute, unknown;
+ to->queryMissing(PathSet(paths2.begin(), paths2.end()),
+ willBuild, willSubstitute, unknown, downloadSize, narSize);
+ /* FIXME: should use ensurePath(), but it only
+ does one path at a time. */
+ if (!willSubstitute.empty())
+ try {
+ to->buildPaths(willSubstitute);
+ } catch (Error & e) {
+ printMsg(lvlError, format("warning: %1%") % e.msg());
+ }
+ }
+
std::string copiedLabel = "copied";
logger->setExpected(copiedLabel, storePaths.size());