// RUN: %clang_cc1 -fsyntax-only -verify %s // RUN: %clang_cc1 -fsyntax-only -verify -std=c++98 %s // RUN: %clang_cc1 -fsyntax-only -verify -std=c++11 %s struct A { int x; }; // expected-note@-1 {{candidate constructor (the implicit copy constructor) not viable: no known conversion from 'int' to 'const A' for 1st argument}} #if __cplusplus >= 201103L // expected-note@-3 {{candidate constructor (the implicit move constructor) not viable: no known conversion from 'int' to 'A' for 1st argument}} #endif // expected-note@-5 {{candidate constructor (the implicit default constructor) not viable: requires 0 arguments, but 1 was provided}} class Base { public: virtual void f(); }; class Derived : public Base { }; struct ConvertibleToInt { operator int() const; }; struct Constructible { Constructible(int, float); }; // --------------------------------------------------------------------- // C-style casts // --------------------------------------------------------------------- template<typename T, typename U> struct CStyleCast0 { void f(T t) { (void)((U)t); // expected-error{{cannot convert 'A' to 'int' without a conversion operator}} } }; template struct CStyleCast0<int, float>; template struct CStyleCast0<A, int>; // expected-note{{instantiation}} // --------------------------------------------------------------------- // static_cast // --------------------------------------------------------------------- template<typename T, typename U> struct StaticCast0 { void f(T t) { (void)static_cast<U>(t); // expected-error{{no matching conversion for static_cast from 'int' to 'A'}} } }; template struct StaticCast0<ConvertibleToInt, bool>; template struct StaticCast0<int, float>; template struct StaticCast0<int, A>; // expected-note{{instantiation}} // --------------------------------------------------------------------- // dynamic_cast // --------------------------------------------------------------------- template<typename T, typename U> struct DynamicCast0 { void f(T t) { (void)dynamic_cast<U>(t); // expected-error{{not a reference or pointer}} } }; template struct DynamicCast0<Base*, Derived*>; template struct DynamicCast0<Base*, A>; // expected-note{{instantiation}} // --------------------------------------------------------------------- // reinterpret_cast // --------------------------------------------------------------------- template<typename T, typename U> struct ReinterpretCast0 { void f(T t) { (void)reinterpret_cast<U>(t); // expected-error{{qualifiers}} } }; template struct ReinterpretCast0<void (*)(int), void (*)(float)>; template struct ReinterpretCast0<int const *, float *>; // expected-note{{instantiation}} // --------------------------------------------------------------------- // const_cast // --------------------------------------------------------------------- template<typename T, typename U> struct ConstCast0 { void f(T t) { (void)const_cast<U>(t); // expected-error{{not allowed}} } }; template struct ConstCast0<int const * *, int * *>; template struct ConstCast0<int const *, float *>; // expected-note{{instantiation}} // --------------------------------------------------------------------- // C++ functional cast // --------------------------------------------------------------------- template<typename T, typename U> struct FunctionalCast1 { void f(T t) { (void)U(t); // expected-error{{cannot convert 'A' to 'int' without a conversion operator}} } }; template struct FunctionalCast1<int, float>; template struct FunctionalCast1<A, int>; // expected-note{{instantiation}} // Generates temporaries, which we cannot handle yet. template<int N, long M> struct FunctionalCast2 { void f() { (void)Constructible(N, M); } }; template struct FunctionalCast2<1, 3>; // --------------------------------------------------------------------- // implicit casting // --------------------------------------------------------------------- template<typename T> struct Derived2 : public Base { }; void test_derived_to_base(Base *&bp, Derived2<int> *dp) { bp = dp; }