Этот код не компилируется в Clang (6,7,8,9, транк), но прекрасно компилируется в GCC (7.1, 8.1, 9.1):
template<class T> struct TypeHolder { using type = T; };
template<int i>
class Outer {
private:
template<class T>
static constexpr auto compute_type() {
if constexpr (i == 42) {
return TypeHolder<bool>{};
} else {
return TypeHolder<T>{};
}
}
public:
template<class T>
using TheType = typename decltype(Outer<i>::compute_type<T>())::type;
};
int main() {
Outer<42>::TheType<int> i;
}
Clang говорит мне:
<source>:17:49: error: 'compute_type' is a private member of 'Outer<42>'
... что, конечно, есть, но я пытаюсь получить доступ , что элемент из внутри одного класса. Я не понимаю, почему это не должно быть доступно там. Я ударил (и я должен подать) ошибку Clang?
Вы можете поиграть с кодом в проводнике компилятора Годболта .
Веселая! Тем не менее, проверка доступа обязательно должна быть сделана с «разрешениями»
—
Лукас Барт
Outer<42>
, не так main
ли? Выглядит даже больше как ошибка для меня сейчас.
Работает ли
—
Брэндон
std::result_of
вместо этого?
FWIW, также работает в ICC и MSVC.
—
ChrisMM
friend int main();
останавливает Clang от жалоб.