boost::variant & c++11
data:image/s3,"s3://crabby-images/95bd9/95bd9263468783b906c4720588743c59ec9c04a1" alt=""
Hi -
I seem to have run into a regression with boost::variant from 1.48 to
1.53. With C++11 enabled, using g++, the following code seems to confuse
variant's constructor selection machinery: if you look at the line after
#ifndef WAR, the implicit conversion isn't happening, and so boost::variant
attempts to convert construct from extract
data:image/s3,"s3://crabby-images/82c71/82c710aa0a57b507807e0d35a3199f81ab9d8c67" alt=""
#include
//A simplified wrapper template<typename T> struct wrap { T t; wrap(T& _t) : t(_t) {} operator T() const { return t; } T force() const { return t; } }; struct A{}; struct B{};
typedef boost::variant my_variant;
int main() { A a; my_variant x(a); #ifndef WAR my_variant y = wrap
(x); #else my_variant y = wrap (x).force(); #endif } And the error:
/home/bcatanzaro/boost_1_53_0/boost/variant/variant.hpp:1574:9: error: no matching function for call to ‘boost::variant::initializer::initialize(void*, std::remove_reference
>&>::type)’
FWIW, your case can be reproduced with even more trivial code:
#include
data:image/s3,"s3://crabby-images/4196f/4196f8ea6beafecb2e3130c9b6cb6165adaac5ee" alt=""
2013/5/8 Igor R
#include
//A simplified wrapper template<typename T> struct wrap { T t; wrap(T& _t) : t(_t) {} operator T() const { return t; } T force() const { return t; } }; struct A{}; struct B{};
typedef boost::variant my_variant;
int main() { A a; my_variant x(a); #ifndef WAR my_variant y = wrap
(x); #else my_variant y = wrap (x).force(); #endif } And the error:
/home/bcatanzaro/boost_1_53_0/boost/variant/variant.hpp:1574:9: error: no matching function for call to ‘boost::variant::initializer::initialize(void*, std::remove_reference
>&>::type)’ FWIW, your case can be reproduced with even more trivial code:
#include
typedef boost::variant<int> my_variant; struct convertible { operator my_variant() const { return my_variant(); } };
int main() { convertible x; my_variant y = x; }
I'll take care of that issue, but not 100% sure that there will be enough time to push fix to 1.54. There is a ticket for that issue: https://svn.boost.org/trac/boost/ticket/8555 . -- Best regards, Antony Polukhin
data:image/s3,"s3://crabby-images/4196f/4196f8ea6beafecb2e3130c9b6cb6165adaac5ee" alt=""
2013/5/10 Antony Polukhin
2013/5/8 Igor R
: #include
//A simplified wrapper template<typename T> struct wrap { T t; wrap(T& _t) : t(_t) {} operator T() const { return t; } T force() const { return t; } }; struct A{}; struct B{};
typedef boost::variant my_variant;
int main() { A a; my_variant x(a); #ifndef WAR my_variant y = wrap
(x); #else my_variant y = wrap (x).force(); #endif }
Reproduced that error on 1.48.0 using MSVC.
FWIW, your case can be reproduced with even more trivial code:
#include
typedef boost::variant<int> my_variant; struct convertible { operator my_variant() const { return my_variant(); } };
int main() { convertible x; my_variant y = x; }
Reproduced that error on 1.48.0 using MSVC. Looks like this problem is not affected by latest changes in Boost. Have you changed the compiler during migration to Boost 1.53? Have been some code changes made during migration? Do you compile with same options before and after migration? -- Best regards, Antony Polukhin
participants (3)
-
Antony Polukhin
-
Bryan Catanzaro
-
Igor R