llvm-project/clang/test/SemaCXX/copy-initialization.cpp

44 lines
1.0 KiB
C++

// RUN: %clang_cc1 -fsyntax-only -verify %s
class X {
public:
explicit X(const X&);
X(int*); // expected-note 2{{candidate constructor}}
explicit X(float*);
};
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}}
}
struct foo {
void bar();
};
// PR3600
void test(const foo *P) { P->bar(); } // expected-error{{cannot initialize object parameter of type 'foo' with an expression of type 'foo const'}}
namespace PR6757 {
struct Foo {
Foo();
Foo(Foo&);
};
struct Bar {
operator const Foo&() const;
};
void f(Foo); // expected-note{{candidate function not viable: no known conversion from 'PR6757::Bar' to 'PR6757::Foo' for 1st argument}}
// FIXME: This isn't really the right reason for the failure. We
// should fail after overload resolution.
void g(Foo foo) {
f(Bar()); // expected-error{{no matching function for call to 'f'}}
f(foo);
}
}