diff options
author | Douglas Gregor <dgregor@apple.com> | 2012-02-09 00:47:04 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2012-02-09 00:47:04 +0000 |
commit | 8c50e7c5e380d93f784582579c3e3f1bc157bf12 (patch) | |
tree | d6556ee13f1264af6738a39fd7c043365bfeb166 /clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp | |
parent | f542675ae34943a85ffcdb9d07c69b181c3d869f (diff) | |
download | bcm5719-llvm-8c50e7c5e380d93f784582579c3e3f1bc157bf12.tar.gz bcm5719-llvm-8c50e7c5e380d93f784582579c3e3f1bc157bf12.zip |
Various interrelated cleanups for lambdas:
- Complete the lambda class when we finish the lambda expression
(previously, it was left in the "being completed" state)
- Actually return the LambdaExpr object and bind to the resulting
temporary when needed.
- Detect when cleanups are needed while capturing a variable into a
lambda (e.g., due to default arguments in the copy constructor), and
make sure those cleanups apply for the whole of the lambda
expression.
llvm-svn: 150123
Diffstat (limited to 'clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp')
-rw-r--r-- | clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp b/clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp index 3c5ac220a1e..e816426cbf9 100644 --- a/clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp +++ b/clang/test/CXX/expr/expr.prim/expr.prim.lambda/p7.cpp @@ -2,7 +2,7 @@ // Check that analysis-based warnings work in lambda bodies. void analysis_based_warnings() { - []() -> int { }; // expected-warning{{control reaches end of non-void function}} \ + (void)[]() -> int { }; // expected-warning{{control reaches end of non-void function}} \ // expected-error{{lambda expressions are not supported yet}} } @@ -12,32 +12,32 @@ int &check_const_int(int&); float &check_const_int(const int&); void test_capture_constness(int i, const int ic) { - [i,ic] ()->void { // expected-error{{lambda expressions are not supported yet}} + (void)[i,ic] ()->void { // expected-error{{lambda expressions are not supported yet}} float &fr1 = check_const_int(i); float &fr2 = check_const_int(ic); }; - [=] ()->void { // expected-error{{lambda expressions are not supported yet}} + (void)[=] ()->void { // expected-error{{lambda expressions are not supported yet}} float &fr1 = check_const_int(i); float &fr2 = check_const_int(ic); }; - [i,ic] () mutable ->void { // expected-error{{lambda expressions are not supported yet}} + (void)[i,ic] () mutable ->void { // expected-error{{lambda expressions are not supported yet}} int &ir = check_const_int(i); float &fr = check_const_int(ic); }; - [=] () mutable ->void { // expected-error{{lambda expressions are not supported yet}} + (void)[=] () mutable ->void { // expected-error{{lambda expressions are not supported yet}} int &ir = check_const_int(i); float &fr = check_const_int(ic); }; - [&i,&ic] ()->void { // expected-error{{lambda expressions are not supported yet}} + (void)[&i,&ic] ()->void { // expected-error{{lambda expressions are not supported yet}} int &ir = check_const_int(i); float &fr = check_const_int(ic); }; - [&] ()->void { // expected-error{{lambda expressions are not supported yet}} + (void)[&] ()->void { // expected-error{{lambda expressions are not supported yet}} int &ir = check_const_int(i); float &fr = check_const_int(ic); }; |