From 8e258e150743f9d71a7bbd9f70af78a05d354456 Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Tue, 6 Dec 2016 15:54:07 +0200 Subject: Work around wrong static initialization order in VC --- build2/variable.txx | 33 ++++++++++++++++++++++++--------- 1 file changed, 24 insertions(+), 9 deletions(-) (limited to 'build2/variable.txx') diff --git a/build2/variable.txx b/build2/variable.txx index d566a04..8db2ea9 100644 --- a/build2/variable.txx +++ b/build2/variable.txx @@ -357,13 +357,20 @@ namespace build2 } template - const string value_traits>::type_name = string ( - value_traits::type_name) + 's'; + value_traits>::value_type_ex:: + value_type_ex (value_type&& v) + : value_type (move (v)) + { + type_name = value_traits::type_name; + type_name += 's'; + name = type_name.c_str (); + } template - const value_type value_traits>::value_type = // VC14 wants =. + const typename value_traits>::value_type_ex + value_traits>::value_type = build2::value_type // VC14 wants =. { - value_traits>::type_name.c_str (), + nullptr, // Patched above. sizeof (vector), nullptr, // No base. &default_dtor>, @@ -516,14 +523,22 @@ namespace build2 } template - const string value_traits>::type_name = string ( - value_traits::type_name) + '_' + - value_traits::type_name + "_map"; + value_traits>::value_type_ex:: + value_type_ex (value_type&& v) + : value_type (move (v)) + { + type_name = value_traits::type_name; + type_name += '_'; + type_name += value_traits::type_name; + type_name += "_map"; + name = type_name.c_str (); + } template - const value_type value_traits>::value_type = // VC14 wants =. + const typename value_traits>::value_type_ex + value_traits>::value_type = build2::value_type // VC14 wants = { - value_traits>::type_name.c_str (), + nullptr, // Patched above. sizeof (map), nullptr, // No base. &default_dtor>, -- cgit v1.1