From 0342dc2fcdd78ef28a4e59d84193a3807068d726 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Mon, 11 Apr 2016 07:57:19 +0200 Subject: New configuration logic, iteration 1 --- build2/bin/module | 2 +- build2/bin/module.cxx | 25 ++++++++++++------------- 2 files changed, 13 insertions(+), 14 deletions(-) (limited to 'build2/bin') diff --git a/build2/bin/module b/build2/bin/module index 765eb2c..44dfbc7 100644 --- a/build2/bin/module +++ b/build2/bin/module @@ -16,7 +16,7 @@ namespace build2 { extern "C" bool bin_init ( - scope&, scope&, const location&, unique_ptr&, bool, bool); + scope&, scope&, const location&, unique_ptr&, bool, bool); } } diff --git a/build2/bin/module.cxx b/build2/bin/module.cxx index 5b1d8ca..866bab2 100644 --- a/build2/bin/module.cxx +++ b/build2/bin/module.cxx @@ -34,7 +34,7 @@ namespace build2 bin_init (scope& r, scope& b, const location&, - unique_ptr&, + unique_ptr&, bool first, bool) { @@ -47,17 +47,16 @@ namespace build2 { auto& v (var_pool); - // @@ OVR + // Note: some overridable, some not. // + v.insert ("config.bin.ar", true); + v.insert ("config.bin.ranlib", true); - v.insert ("config.bin.ar"); - v.insert ("config.bin.ranlib"); - - v.insert ("config.bin.lib"); - v.insert ("config.bin.exe.lib"); - v.insert ("config.bin.liba.lib"); - v.insert ("config.bin.libso.lib"); - v.insert ("config.bin.rpath"); + v.insert ("config.bin.lib", true); + v.insert ("config.bin.exe.lib", true); + v.insert ("config.bin.liba.lib", true); + v.insert ("config.bin.libso.lib", true); + v.insert ("config.bin.rpath", true); v.insert ("bin.lib"); v.insert ("bin.exe.lib"); @@ -65,7 +64,7 @@ namespace build2 v.insert ("bin.libso.lib"); v.insert ("bin.rpath"); - v.insert ("bin.libprefix"); + v.insert ("bin.libprefix", true); } // Register target types. @@ -158,8 +157,8 @@ namespace build2 // This one is optional and we merge it into bin.rpath, if any. // See the cxx module for details on merging. // - if (const value& v = config::optional (r, "config.bin.rpath")) - b.assign ("bin.rpath") += cast (v); + b.assign ("bin.rpath") += cast_null ( + config::optional (r, "config.bin.rpath")); // config.bin.ar // config.bin.ranlib -- cgit v1.1