// RUN: %clang_cc1 -triple x86_64-linux-gnu -fms-compatibility -fms-extensions -fsyntax-only -verify -std=c++11 %s // RUN: %clang_cc1 -triple i686-pc-win32 -fms-compatibility -fms-extensions -fsyntax-only -verify -std=c++11 -DMS %s template <bool> struct enable_if {}; template<> struct enable_if<true> { typedef void type; }; template <typename, typename> struct is_same { static constexpr bool value = false; }; template <typename T> struct is_same<T, T> { static constexpr bool value = true; }; struct S { // The only numeric types S can be converted to is __int128 and __float128. template <typename T, typename = typename enable_if< !((__is_integral(T) && sizeof(T) != 16) || is_same<T, float>::value || is_same<T, double>::value || is_same<T, long double>::value)>::type> operator T() { return T(); } }; void f() { #ifdef MS // When targeting Win32, __float128 and __int128 do not exist, so the S // object cannot be converted to anything usable in the expression. // expected-error@+2{{invalid operands to binary expression ('S' and 'double')}} #endif double d = S() + 1.0; #ifndef MS // expected-error@-2{{use of overloaded operator '+' is ambiguous}} // expected-note@-3 36{{built-in candidate operator+}} #endif } |