| // RUN: %clang_cc1 -fsyntax-only -verify %s |
| |
| // --------------------------------------------------------------------- |
| // Imaginary literals |
| // --------------------------------------------------------------------- |
| template<typename T> |
| struct ImaginaryLiteral0 { |
| void f(T &x) { |
| x = 3.0I; // expected-error{{incompatible type}} |
| } |
| }; |
| |
| template struct ImaginaryLiteral0<_Complex float>; |
| template struct ImaginaryLiteral0<int*>; // expected-note{{instantiation}} |
| |
| // --------------------------------------------------------------------- |
| // Compound assignment operator |
| // --------------------------------------------------------------------- |
| namespace N1 { |
| struct X { }; |
| |
| int& operator+=(X&, int); // expected-note{{candidate}} |
| } |
| |
| namespace N2 { |
| long& operator+=(N1::X&, long); // expected-note{{candidate}} |
| |
| template<typename T, typename U, typename Result> |
| struct PlusEquals0 { |
| void f(T t, U u) { |
| Result r = t += u; // expected-error{{ambiguous}} |
| } |
| }; |
| } |
| |
| namespace N3 { |
| struct Y : public N1::X { |
| short& operator+=(long); // expected-note{{candidate}} |
| }; |
| } |
| |
| template struct N2::PlusEquals0<N1::X, int, int&>; |
| template struct N2::PlusEquals0<N1::X, long, long&>; |
| template struct N2::PlusEquals0<N3::Y, long, short&>; |
| template struct N2::PlusEquals0<int, int, int&>; |
| template struct N2::PlusEquals0<N3::Y, int, short&>; // expected-note{{instantiation}} |
| |
| // --------------------------------------------------------------------- |
| // Conditional operator |
| // --------------------------------------------------------------------- |
| template<typename T, typename U, typename Result> |
| struct Conditional0 { |
| void f(T t, U u) { |
| Result result = t? : u; |
| } |
| }; |
| |
| template struct Conditional0<int, int, int>; |
| |
| // --------------------------------------------------------------------- |
| // Statement expressions |
| // --------------------------------------------------------------------- |
| template<typename T> |
| struct StatementExpr0 { |
| void f(T t) { |
| (void)({ |
| if (t) // expected-error{{contextually convertible}} |
| t = t + 17; |
| t + 12; // expected-error{{invalid operands}} |
| }); |
| } |
| }; |
| |
| template struct StatementExpr0<int>; |
| template struct StatementExpr0<N1::X>; // expected-note{{instantiation}} |
| |
| // --------------------------------------------------------------------- |
| // __builtin_choose_expr |
| // --------------------------------------------------------------------- |
| template<bool Cond, typename T, typename U, typename Result> |
| struct Choose0 { |
| void f(T t, U u) { |
| Result r = __builtin_choose_expr(Cond, t, u); // expected-error{{lvalue}} |
| } |
| }; |
| |
| template struct Choose0<true, int, float, int&>; |
| template struct Choose0<false, int, float, float&>; |
| template struct Choose0<true, int, float, float&>; // expected-note{{instantiation}} |
| |
| // --------------------------------------------------------------------- |
| // __builtin_va_arg |
| // --------------------------------------------------------------------- |
| template<typename ArgType> |
| struct VaArg0 { |
| void f(int n, ...) { |
| __builtin_va_list va; |
| __builtin_va_start(va, n); |
| for (int i = 0; i != n; ++i) |
| (void)__builtin_va_arg(va, ArgType); |
| __builtin_va_end(va); |
| } |
| }; |
| |
| template struct VaArg0<int>; |
| |
| template<typename VaList, typename ArgType> |
| struct VaArg1 { |
| void f(int n, ...) { |
| VaList va; |
| __builtin_va_start(va, n); // expected-error{{int}} |
| for (int i = 0; i != n; ++i) |
| (void)__builtin_va_arg(va, ArgType); // expected-error{{int}} |
| __builtin_va_end(va); // expected-error{{int}} |
| } |
| }; |
| |
| template struct VaArg1<__builtin_va_list, int>; |
| template struct VaArg1<int, int>; // expected-note{{instantiation}} |