diff options
Diffstat (limited to 'build2/algorithm.cxx')
-rw-r--r-- | build2/algorithm.cxx | 46 |
1 files changed, 32 insertions, 14 deletions
diff --git a/build2/algorithm.cxx b/build2/algorithm.cxx index a55b885..cbe27b6 100644 --- a/build2/algorithm.cxx +++ b/build2/algorithm.cxx @@ -768,28 +768,46 @@ namespace build2 // If root scope is NULL, then this can mean that we are out of any // project or if the directory is in src_root. In both cases we don't - // inject anything. + // inject anything unless explicitly requested. // // Note that we also used to bail out if this is the root of the // project. But that proved not to be such a great idea in case of // subprojects (e.g., tests/). // - if (rs == nullptr) - return nullptr; + const fsdir* r (nullptr); + if (rs != nullptr && !d.sub (rs->src_path ())) + { + l6 ([&]{trace << d << " for " << t;}); - // Handle the src_root = out_root. - // - if (d.sub (rs->src_path ())) - return nullptr; + // Target is in the out tree, so out directory is empty. + // + r = &search<fsdir> (t, d, dir_path (), string (), nullptr, nullptr); + } + else + { + // See if one was mentioned explicitly. + // + for (const prerequisite& p: group_prerequisites (t)) + { + if (p.is_a<fsdir> ()) + { + const target& pt (search (t, p)); - l6 ([&]{trace << d << " for " << t;}); + if (pt.dir == d) + { + r = &pt.as<fsdir> (); + break; + } + } + } + } + + if (r != nullptr) + { + match (a, *r); + t.prerequisite_targets.emplace_back (r); + } - // Target is in the out tree, so out directory is empty. - // - const fsdir* r ( - &search<fsdir> (t, d, dir_path (), string (), nullptr, nullptr)); - match (a, *r); - t.prerequisite_targets.emplace_back (r); return r; } |