Il seguente codice viene compilato con GCC 4.9.2 ma non con Clang 3.5.0:Gli operatori di conversione espliciti sono consentiti negli elenchi di inizializzazione rinforzati?
#include <string>
class Foo
{
public:
explicit operator std::string() const;
};
std::string bar{Foo{}}; // Works in g++, fails in clang++
std::string baz(Foo{}); // Works in both
clang ++ dice:
foo.cpp:9:13: error: no matching constructor for initialization of 'std::string'
(aka 'basic_string<char>')
std::string bar{Foo{}};
^~~~~~~~
...: note: candidate constructor not viable: no known conversion from 'Foo' to
'const std::basic_string<char> &' for 1st argument
basic_string(const basic_string& __str);
^
Curiosamente, se funziona std::string
è sostituito con un tipo primitivo come int
.
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=51553 e il clangore legata non bug sono probabilmente rilevanti –