From 682836daacdd3dc486187c9d60479b372895a470 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Sat, 29 Jul 2017 10:32:36 +0200 Subject: Implement "see through" installation semantics for utility libraries --- build2/cc/module.cxx | 28 ++++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) (limited to 'build2/cc/module.cxx') diff --git a/build2/cc/module.cxx b/build2/cc/module.cxx index 2b19e70..56b74e9 100644 --- a/build2/cc/module.cxx +++ b/build2/cc/module.cxx @@ -425,20 +425,32 @@ namespace build2 r.insert (perform_clean_id, x_link, lr); r.insert (configure_update_id, x_link, lr); - // Note that libu*{} are not installable. + // Note that while libu*{} are not installable, we need to see through + // them in case they depend on stuff that we need to install (see the + // install rule implementations for details). // if (install_loaded) { - const install& ir (*this); + const file_install& fr (*this); + const alias_install& ar (*this); - r.insert (perform_install_id, x_install, ir); - r.insert (perform_uninstall_id, x_uninstall, ir); + r.insert (perform_install_id, x_install, fr); + r.insert (perform_uninstall_id, x_uninstall, fr); - r.insert (perform_install_id, x_install, ir); - r.insert (perform_uninstall_id, x_uninstall, ir); + r.insert (perform_install_id, x_install, fr); + r.insert (perform_uninstall_id, x_uninstall, fr); - r.insert (perform_install_id, x_install, ir); - r.insert (perform_uninstall_id, x_uninstall, ir); + r.insert (perform_install_id, x_install, fr); + r.insert (perform_uninstall_id, x_uninstall, fr); + + r.insert (perform_install_id, x_install, ar); + r.insert (perform_uninstall_id, x_uninstall, ar); + + r.insert (perform_install_id, x_install, ar); + r.insert (perform_uninstall_id, x_uninstall, ar); + + r.insert (perform_install_id, x_install, ar); + r.insert (perform_uninstall_id, x_uninstall, ar); } } } -- cgit v1.1