diff options
Diffstat (limited to 'test/CXX/expr/expr.prim/expr.prim.lambda/p14.cpp')
-rw-r--r-- | test/CXX/expr/expr.prim/expr.prim.lambda/p14.cpp | 20 |
1 files changed, 18 insertions, 2 deletions
diff --git a/test/CXX/expr/expr.prim/expr.prim.lambda/p14.cpp b/test/CXX/expr/expr.prim/expr.prim.lambda/p14.cpp index 0bbb9ae744..4c876d7480 100644 --- a/test/CXX/expr/expr.prim/expr.prim.lambda/p14.cpp +++ b/test/CXX/expr/expr.prim/expr.prim.lambda/p14.cpp @@ -6,10 +6,26 @@ class NonCopyable { void capture_by_copy(NonCopyable nc, NonCopyable &ncr) { // FIXME: error messages should talk about capture - [nc] { }; // expected-error{{field of type 'NonCopyable' has private copy constructor}} \ + (void)[nc] { }; // expected-error{{field of type 'NonCopyable' has private copy constructor}} \ // expected-error{{lambda expressions are not supported yet}} - [ncr] { }; // expected-error{{field of type 'NonCopyable' has private copy constructor}} \ + (void)[ncr] { }; // expected-error{{field of type 'NonCopyable' has private copy constructor}} \ // expected-error{{lambda expressions are not supported yet}} } +struct NonTrivial { + NonTrivial(); + NonTrivial(const NonTrivial &); + ~NonTrivial(); +}; + +struct CopyCtorDefault { + CopyCtorDefault(const CopyCtorDefault&, NonTrivial nt = NonTrivial()); + + void foo() const; +}; + +void capture_with_default_args(CopyCtorDefault cct) { + (void)[=] () -> void { cct.foo(); }; // expected-error{{lambda expressions are not supported yet}} +} + // FIXME: arrays! |