2011-10-14 06:29:44 +08:00
|
|
|
// RUN: %clang_cc1 -fsyntax-only -verify %s -std=c++11
|
2009-10-02 04:39:51 +08:00
|
|
|
|
|
|
|
struct R {
|
|
|
|
R(int);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct A {
|
|
|
|
A(R);
|
|
|
|
};
|
|
|
|
|
2011-08-31 03:58:05 +08:00
|
|
|
struct B { // expected-note 3 {{candidate constructor (the implicit copy constructor) not viable}} \
|
|
|
|
expected-note 3 {{candidate constructor (the implicit move constructor) not viable}}
|
2011-02-15 02:34:10 +08:00
|
|
|
B(A); // expected-note 3 {{candidate constructor not viable}}
|
2009-10-02 04:39:51 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
int main () {
|
2011-02-15 02:34:10 +08:00
|
|
|
B(10); // expected-error {{no matching conversion for functional-style cast from 'int' to 'B'}}
|
|
|
|
(B)10; // expected-error {{no matching conversion for C-style cast from 'int' to 'B'}}
|
|
|
|
static_cast<B>(10); // expected-error {{no matching conversion for static_cast from 'int' to 'B'}} \\
|
2010-09-20 07:03:35 +08:00
|
|
|
// expected-warning {{expression result unused}}
|
2009-10-02 04:39:51 +08:00
|
|
|
}
|
|
|
|
|
2009-11-06 09:14:41 +08:00
|
|
|
template<class T>
|
|
|
|
struct X0 {
|
|
|
|
X0(const T &);
|
|
|
|
};
|
|
|
|
|
|
|
|
template<class T>
|
|
|
|
X0<T> make_X0(const T &Val) {
|
|
|
|
return X0<T>(Val);
|
|
|
|
}
|
|
|
|
|
|
|
|
void test_X0() {
|
2010-02-09 15:26:29 +08:00
|
|
|
const char array[2] = { 'a', 'b' };
|
2009-11-06 09:14:41 +08:00
|
|
|
make_X0(array);
|
|
|
|
}
|
2009-11-06 13:48:00 +08:00
|
|
|
|
|
|
|
// PR5210 recovery
|
|
|
|
class C {
|
|
|
|
protected:
|
|
|
|
template <int> float* &f0(); // expected-note{{candidate}}
|
|
|
|
template <unsigned> float* &f0(); // expected-note{{candidate}}
|
|
|
|
|
|
|
|
void f1() {
|
|
|
|
static_cast<float*>(f0<0>()); // expected-error{{ambiguous}}
|
|
|
|
}
|
|
|
|
};
|