From 9f01a3f0a87679ac3ba2c71ab6d31478bcbef481 Mon Sep 17 00:00:00 2001 From: AmineChikhaoui Date: Wed, 25 Oct 2017 16:13:49 +0100 Subject: attempt to fix #1630: make the queries of store paths run in parallel using a thread pool --- src/libstore/store-api.cc | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'src') diff --git a/src/libstore/store-api.cc b/src/libstore/store-api.cc index c57e42fec..82e0bda54 100644 --- a/src/libstore/store-api.cc +++ b/src/libstore/store-api.cc @@ -389,8 +389,9 @@ PathSet Store::queryValidPaths(const PathSet & paths, SubstituteFlag maybeSubsti Sync state_(State{paths.size(), PathSet()}); std::condition_variable wakeup; + ThreadPool pool; - for (auto & path : paths) + auto doQuery = [&](const Path & path ) { queryPathInfo(path, [path, &state_, &wakeup](ref info) { auto state(state_.lock()); @@ -411,6 +412,12 @@ PathSet Store::queryValidPaths(const PathSet & paths, SubstituteFlag maybeSubsti if (!--state->left) wakeup.notify_one(); }); + }; + + for (auto & path : paths) + pool.enqueue(std::bind(doQuery, path)); + + pool.process(); while (true) { auto state(state_.lock()); -- cgit v1.2.3