diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2015-11-22 07:33:28 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2015-11-22 07:33:28 +0000 |
commit | 71d403effb18037735c42cd234b876b636afba9d (patch) | |
tree | 78fc50b113822f70b5a6ba02b0ec3dfcb997e43e /clang/test/SemaCXX/coroutines.cpp | |
parent | 4ba66602bd7850e1648a5a4a2b07b0ab558af4e9 (diff) | |
download | bcm5719-llvm-71d403effb18037735c42cd234b876b636afba9d.tar.gz bcm5719-llvm-71d403effb18037735c42cd234b876b636afba9d.zip |
[coroutines] Check for overload sets in co_yield / co_return operands being resolved by a call to yield_value / return_value before rejecting them.
llvm-svn: 253817
Diffstat (limited to 'clang/test/SemaCXX/coroutines.cpp')
-rw-r--r-- | clang/test/SemaCXX/coroutines.cpp | 36 |
1 files changed, 28 insertions, 8 deletions
diff --git a/clang/test/SemaCXX/coroutines.cpp b/clang/test/SemaCXX/coroutines.cpp index 85cc919c6d1..af50eabb245 100644 --- a/clang/test/SemaCXX/coroutines.cpp +++ b/clang/test/SemaCXX/coroutines.cpp @@ -49,11 +49,11 @@ struct yielded_thing { const char *p; short a, b; }; struct not_awaitable {}; struct promise { - awaitable yield_value(int); // expected-note {{candidate}} - awaitable yield_value(yielded_thing); // expected-note {{candidate}} - not_awaitable yield_value(void()); // expected-note {{candidate}} + awaitable yield_value(int); // expected-note 2{{candidate}} + awaitable yield_value(yielded_thing); // expected-note 2{{candidate}} + not_awaitable yield_value(void()); // expected-note 2{{candidate}} void return_void(); - void return_value(int); // expected-note {{here}} + void return_value(int); // expected-note 2{{here}} }; void yield() { @@ -159,17 +159,37 @@ namespace dependent_operator_co_await_lookup { template void await_template_2(outer); } +struct yield_fn_tag {}; +template<> struct std::coroutine_traits<void, yield_fn_tag> { + struct promise_type { + // FIXME: add an await_transform overload for functions + awaitable yield_value(int()); + void return_value(int()); + }; +}; + namespace placeholder { - awaitable f(), f(int); // expected-note 2{{possible target}} - int g(), g(int); // expected-note 4{{possible target}} + awaitable f(), f(int); // expected-note 4{{possible target}} + int g(), g(int); // expected-note 2{{candidate}} void x() { co_await f; // expected-error {{reference to overloaded function}} } void y() { - co_yield g; // expected-error {{reference to overloaded function}} + co_yield g; // expected-error {{no matching member function for call to 'yield_value'}} } void z() { co_await a; - co_return g; // expected-error {{reference to overloaded function}} + co_return g; // expected-error {{address of overloaded function 'g' does not match required type 'int'}} + } + + void x(yield_fn_tag) { + co_await f; // expected-error {{reference to overloaded function}} + } + void y(yield_fn_tag) { + co_yield g; + } + void z(yield_fn_tag) { + co_await a; + co_return g; } } |