diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2012-01-26 03:00:14 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2012-01-26 03:00:14 +0000 |
commit | 34b49061aad6d57c60d5bb15ad1cc44ff3968ae7 (patch) | |
tree | 5b8ea285f0097f649e7d098e674f84ad65fdd208 /clang/test | |
parent | e284163990e190b71d7fe99a46aca9063d73396a (diff) | |
download | bcm5719-llvm-34b49061aad6d57c60d5bb15ad1cc44ff3968ae7.tar.gz bcm5719-llvm-34b49061aad6d57c60d5bb15ad1cc44ff3968ae7.zip |
Refactor to share code for handling return statements between lambda expressions and block literals. As it turns out, almost all the logic can be shared.
llvm-svn: 149031
Diffstat (limited to 'clang/test')
-rw-r--r-- | clang/test/Parser/objcxx0x-lambda-expressions.mm | 3 | ||||
-rw-r--r-- | clang/test/SemaCXX/lambda-expressions.cpp | 13 |
2 files changed, 14 insertions, 2 deletions
diff --git a/clang/test/Parser/objcxx0x-lambda-expressions.mm b/clang/test/Parser/objcxx0x-lambda-expressions.mm index 06573b94467..5cfb4f8c5a7 100644 --- a/clang/test/Parser/objcxx0x-lambda-expressions.mm +++ b/clang/test/Parser/objcxx0x-lambda-expressions.mm @@ -14,8 +14,7 @@ class C { [] {}; // expected-error {{lambda expressions are not supported yet}} [=] (int i) {}; // expected-error {{lambda expressions are not supported yet}} [&] (int) mutable -> void {}; // expected-error {{lambda expressions are not supported yet}} - // FIXME: Implicit return type deduction doesn't work yet. - [foo,bar] () { return 3; }; // expected-error {{void function 'f' should not return a value}} expected-error {{lambda expressions are not supported yet}} + [foo,bar] () { return 3; }; // expected-error {{lambda expressions are not supported yet}} [=,&foo] () {}; // expected-error {{lambda expressions are not supported yet}} [this] () {}; // expected-error {{lambda expressions are not supported yet}} } diff --git a/clang/test/SemaCXX/lambda-expressions.cpp b/clang/test/SemaCXX/lambda-expressions.cpp index 9411c34ec8d..db934c3ab77 100644 --- a/clang/test/SemaCXX/lambda-expressions.cpp +++ b/clang/test/SemaCXX/lambda-expressions.cpp @@ -52,3 +52,16 @@ namespace ExplicitCapture { [this] () {}; // expected-error {{invalid use of 'this'}} expected-error {{not supported yet}} } } + +namespace ReturnDeduction { + void test() { + [](){ return 1; }; // expected-error {{not supported yet}} + [](){ return 1; }; // expected-error {{not supported yet}} + [](){ return ({return 1; 1;}); }; // expected-error {{not supported yet}} + [](){ return ({return 'c'; 1;}); }; // expected-error {{not supported yet}} expected-error {{must match previous return type}} + []()->int{ return 'c'; return 1; }; // expected-error {{not supported yet}} + [](){ return 'c'; return 1; }; // expected-error {{not supported yet}} expected-error {{must match previous return type}} + // FIXME: Need to check structure of lambda body + [](){ return 1; return 1; }; // expected-error {{not supported yet}} + } +} |