// RUN: %clang_cc1 -fsyntax-only -std=c++11 %s -verify template<typename T> void capture(const T&); class NonCopyable { NonCopyable(const NonCopyable&); // expected-note 2 {{implicitly declared private here}} public: void foo() const; }; class NonConstCopy { public: NonConstCopy(NonConstCopy&); // expected-note{{would lose const}} }; void capture_by_copy(NonCopyable nc, NonCopyable &ncr, const NonConstCopy nco) { (void)[nc] { }; // expected-error{{capture of variable 'nc' as type 'NonCopyable' calls private copy constructor}} (void)[=] { ncr.foo(); // expected-error{{capture of variable 'ncr' as type 'NonCopyable' calls private copy constructor}} }(); [nco] {}(); // expected-error{{no matching constructor for initialization of 'const NonConstCopy'}} } struct NonTrivial { NonTrivial(); NonTrivial(const NonTrivial &); ~NonTrivial(); }; struct CopyCtorDefault { CopyCtorDefault(); CopyCtorDefault(const CopyCtorDefault&, NonTrivial nt = NonTrivial()); void foo() const; }; void capture_with_default_args(CopyCtorDefault cct) { (void)[=] () -> void { cct.foo(); }; } struct ExpectedArrayLayout { CopyCtorDefault array[3]; }; void capture_array() { CopyCtorDefault array[3]; auto x = [=]() -> void { capture(array[0]); }; static_assert(sizeof(x) == sizeof(ExpectedArrayLayout), "layout mismatch"); } // Check for the expected non-static data members. struct ExpectedLayout { char a; short b; }; void test_layout(char a, short b) { auto x = [=] () -> void { capture(a); capture(b); }; static_assert(sizeof(x) == sizeof(ExpectedLayout), "Layout mismatch!"); } struct ExpectedThisLayout { ExpectedThisLayout* a; void f() { auto x = [this]() -> void {}; static_assert(sizeof(x) == sizeof(ExpectedThisLayout), "Layout mismatch!"); } };