forked from OSchip/llvm-project
126 lines
2.7 KiB
C++
126 lines
2.7 KiB
C++
// RUN: %clang_cc1 -std=c++11 -verify %s
|
|
|
|
// rdar://12240916 stack overflow.
|
|
namespace rdar12240916 {
|
|
|
|
struct S2 {
|
|
S2(const S2&);
|
|
S2();
|
|
};
|
|
|
|
struct S { // expected-note {{not complete}}
|
|
S x; // expected-error {{incomplete type}}
|
|
S2 y;
|
|
};
|
|
|
|
S foo() {
|
|
S s;
|
|
return s;
|
|
}
|
|
|
|
struct S3; // expected-note {{forward declaration}}
|
|
|
|
struct S4 {
|
|
S3 x; // expected-error {{incomplete type}}
|
|
S2 y;
|
|
};
|
|
|
|
struct S3 {
|
|
S4 x;
|
|
S2 y;
|
|
};
|
|
|
|
S4 foo2() {
|
|
S4 s;
|
|
return s;
|
|
}
|
|
|
|
}
|
|
|
|
// rdar://12542261 stack overflow.
|
|
namespace rdar12542261 {
|
|
|
|
template <class _Tp>
|
|
struct check_complete
|
|
{
|
|
static_assert(sizeof(_Tp) > 0, "Type must be complete.");
|
|
};
|
|
|
|
|
|
template<class _Rp>
|
|
class function // expected-note 2 {{candidate}}
|
|
{
|
|
public:
|
|
template<class _Fp>
|
|
function(_Fp, typename check_complete<_Fp>::type* = 0); // expected-note {{candidate}}
|
|
};
|
|
|
|
void foobar()
|
|
{
|
|
auto LeftCanvas = new Canvas(); // expected-error {{unknown type name}}
|
|
function<void()> m_OnChange = [&, LeftCanvas]() { }; // expected-error {{no viable conversion}}
|
|
}
|
|
|
|
}
|
|
|
|
namespace b6981007 {
|
|
struct S {}; // expected-note 3{{candidate}}
|
|
void f() {
|
|
S s(1, 2, 3); // expected-error {{no matching}}
|
|
for (auto x : s) { // expected-error {{invalid range expression of}}
|
|
// We used to attempt to evaluate the initializer of this variable,
|
|
// and crash because it has an undeduced type.
|
|
const int &n(x);
|
|
constexpr int k = sizeof(x);
|
|
}
|
|
}
|
|
}
|
|
|
|
namespace incorrect_auto_type_deduction_for_typo {
|
|
struct S {
|
|
template <typename T> S(T t) {
|
|
(void)sizeof(t);
|
|
(void)new auto(t);
|
|
}
|
|
};
|
|
|
|
void Foo(S);
|
|
|
|
void test(int some_number) { // expected-note {{'some_number' declared here}}
|
|
auto x = sum_number; // expected-error {{use of undeclared identifier 'sum_number'; did you mean 'some_number'?}}
|
|
auto lambda = [x] {};
|
|
Foo(lambda);
|
|
}
|
|
}
|
|
|
|
namespace pr29091 {
|
|
struct X{ X(const X &x); };
|
|
struct Y: X { using X::X; };
|
|
bool foo() { return __has_nothrow_constructor(Y); }
|
|
bool bar() { return __has_nothrow_copy(Y); }
|
|
|
|
struct A { template <typename T> A(); };
|
|
struct B : A { using A::A; };
|
|
bool baz() { return __has_nothrow_constructor(B); }
|
|
bool qux() { return __has_nothrow_copy(B); }
|
|
}
|
|
|
|
namespace undeduced_field {
|
|
template<class T>
|
|
struct Foo {
|
|
typedef T type;
|
|
};
|
|
|
|
struct Bar {
|
|
Bar();
|
|
// The missing expression makes A undeduced.
|
|
static constexpr auto A = ; // expected-error {{expected expression}}
|
|
// expected-error@-1 {{declaration of variable 'A' with deduced type 'const auto' requires an initializer}}
|
|
|
|
Foo<decltype(A)>::type B; // The type of B is also undeduced (wrapped in Elaborated).
|
|
};
|
|
|
|
// This used to crash when trying to get the layout of B.
|
|
Bar x;
|
|
}
|