У меня есть следующий код, который компилируется под g++, но не с clang.
Clang будет компилировать код, если он будет изменен различными способами, например, слияние объявлений пространства имен.
// The problem disappears without namespaces.
namespace Root {
// The problem disappears if 'g' is in the global namespace, and we change
// the friend declaration to '::g'
// The problem disappears if 'g' has void return type.
// The problem disappears if we get rid of the 'Value' template argument
// and the 'value' parameter.
template<typename Value, typename Defaulted = void>
bool g(Value value);
// The problem disappears if MyClass is not a template.
template<typename ClassValue>
class MyClass {
private:
template<typename Value, typename Defaulted>
friend bool g(Value value);
};
}
// The problem disappears if we declare the Root namespace in a single block
// containing 'g', 'MyClass' and 'f'.
// The problem remains if we declare f in the global namespace and reference
// Root::g.
namespace Root {
void f() {
MyClass<int> value;
g(value);
}
}
Скомпилировать с clang:
clang -fsyntax-only -std=c++11 testcase.cpp
Скомпилировать с g++:
g++ -fsyntax-only -std=c++11 testcase.cpp
Версии: g++ 4.9.2, clang 3.6.0, как на ядре Ubuntu 15.04.
Clang дает сообщение об ошибке:
testcase.cpp:24:9: error: no matching function for call to 'g'
g(value);
^
testcase.cpp:14:21: note: candidate template ignored: couldn't infer template argument 'Defaulted'
friend bool g(Value value);
^
1 error generated.