// 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 class X { public: explicit X(const X&); // expected-note {{candidate constructor}} X(int*); // expected-note 3{{candidate constructor}} explicit X(float*); // expected-note {{candidate constructor}} }; class Y : public X { }; void f(Y y, int *ip, float *fp) { X x1 = y; // expected-error{{no matching constructor for initialization of 'X'}} X x2 = 0; X x3 = ip; X x4 = fp; // expected-error{{no viable conversion}} X x2a(0); // expected-error{{call to constructor of 'X' is ambiguous}} X x3a(ip); X x4a(fp); } struct foo { void bar(); // expected-note{{declared here}} }; // PR3600 void test(const foo *P) { P->bar(); } // expected-error{{'this' argument to member function 'bar' has type 'const foo', but function is not marked const}} namespace PR6757 { struct Foo { Foo(); // expected-note{{not viable}} Foo(Foo&); // expected-note{{candidate constructor not viable}} }; struct Bar { operator const Foo&() const; }; void f(Foo); void g(Foo foo) { f(Bar()); // expected-error{{no viable constructor copying parameter of type 'const PR6757::Foo'}} f(foo); } } namespace DR5 { // Core issue 5: if a temporary is created in copy-initialization, it is of // the cv-unqualified version of the destination type. namespace Ex1 { struct C { }; C c; struct A { A(const A&); A(const C&); }; const volatile A a = c; // ok } namespace Ex2 { struct S { S(S&&); #if __cplusplus <= 199711L // C++03 or earlier modes // expected-warning@-2 {{rvalue references are a C++11 extension}} #endif S(int); }; const S a(0); const S b = 0; } } struct A {}; struct B : A { B(); B(B&); B(A); B(int); }; B b = 0; // ok, calls B(int) then A(const A&) then B(A).