diff options
author | Eelco Dolstra <e.dolstra@tudelft.nl> | 2008-08-04T11·44+0000 |
---|---|---|
committer | Eelco Dolstra <e.dolstra@tudelft.nl> | 2008-08-04T11·44+0000 |
commit | 03427e76f11fe1d918020d28bdb69b2fb348ee96 (patch) | |
tree | a9628150b6c2943e1fa99fd03f7fcf4b30ec7bf4 /src/libstore/misc.cc | |
parent | b3c26180e33856f16e1e5ceea30b951065b4ebc1 (diff) |
* querySubstitutablePathInfo: work properly when run via the daemon.
* --dry-run: print the paths that we don't know how to build/substitute.
Diffstat (limited to 'src/libstore/misc.cc')
-rw-r--r-- | src/libstore/misc.cc | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/src/libstore/misc.cc b/src/libstore/misc.cc index acf9346d4bdc..1759f521cc29 100644 --- a/src/libstore/misc.cc +++ b/src/libstore/misc.cc @@ -46,7 +46,7 @@ Path findOutput(const Derivation & drv, string id) void queryMissing(const PathSet & targets, - PathSet & willBuild, PathSet & willSubstitute) + PathSet & willBuild, PathSet & willSubstitute, PathSet & unknown) { PathSet todo(targets.begin(), targets.end()), done; @@ -57,7 +57,10 @@ void queryMissing(const PathSet & targets, done.insert(p); if (isDerivation(p)) { - if (!store->isValidPath(p)) continue; + if (!store->isValidPath(p)) { + unknown.insert(p); + continue; + } Derivation drv = derivationFromPath(p); bool mustBuild = false; @@ -81,12 +84,11 @@ void queryMissing(const PathSet & targets, else { if (store->isValidPath(p)) continue; SubstitutablePathInfo info; - if (dynamic_cast<LocalStore *>(store.get())->querySubstitutablePathInfo(p, info)) { + if (store->querySubstitutablePathInfo(p, info)) { willSubstitute.insert(p); todo.insert(info.references.begin(), info.references.end()); - } - /* Not substitutable and not buildable; should we flag - this? */ + } else + unknown.insert(p); } } } |