From 65ce598d17a662b4c8b9a8df02b619549c5824c3 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Fri, 16 Sep 2022 08:39:05 +0200 Subject: Register fallback dist meta-operation rule for out of project targets The problematic scenario this fixes is an ad hoc pattern rule (which we register for dist in order to inject any additional sources; see parser.cxx for details) that pulls a tool imported from the system (say /usr/bin/xxd). --- libbuild2/config/init.cxx | 6 ++++-- libbuild2/dist/init.cxx | 12 +++++++++++- libbuild2/parser.cxx | 4 +++- 3 files changed, 18 insertions(+), 4 deletions(-) diff --git a/libbuild2/config/init.cxx b/libbuild2/config/init.cxx index e921657..72ded05 100644 --- a/libbuild2/config/init.cxx +++ b/libbuild2/config/init.cxx @@ -702,10 +702,12 @@ namespace build2 // Register alias and fallback rule for the configure meta-operation. // - // We need this rule for out-of-any-project dependencies (e.g., - // libraries imported from /usr/lib). We are registring it on the + // We need this rule for out-of-any-project dependencies (for example, + // libraries imported from /usr/lib). We are registering it on the // global scope similar to builtin rules. // + // See a similar rule in the dist module. + // rs.global_scope ().insert_rule ( configure_id, 0, "config.file", file_rule::instance); diff --git a/libbuild2/dist/init.cxx b/libbuild2/dist/init.cxx index dd8e25b..5e371bf 100644 --- a/libbuild2/dist/init.cxx +++ b/libbuild2/dist/init.cxx @@ -3,8 +3,9 @@ #include -#include #include +#include +#include #include #include @@ -209,6 +210,15 @@ namespace build2 rs.insert_rule (dist_id, 0, "dist", rule_); rs.insert_rule (dist_id, 0, "dist.alias", rule_); + // We need this rule for out-of-any-project dependencies (for example, + // executables imported from /usr/bin, etc). We are registering it on + // the global scope similar to builtin rules. + // + // See a similar rule in the config module. + // + rs.global_scope ().insert_rule ( + dist_id, 0, "dist.file", file_rule::instance); + // Configuration. // // Adjust module priority so that the config.dist.* values are saved at diff --git a/libbuild2/parser.cxx b/libbuild2/parser.cxx index 03b912d..e21fc8d 100644 --- a/libbuild2/parser.cxx +++ b/libbuild2/parser.cxx @@ -1307,7 +1307,9 @@ namespace build2 // recipe for dist. // // And the same for the configure meta-operation to, for - // example, make sure a hinted ad hoc rule matches. + // example, make sure a hinted ad hoc rule matches. @@ Hm, + // maybe we fixed this with action-specific hints? But the + // injection part above may still apply. // if (a.meta_operation () == perform_id) { -- cgit v1.1