mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-18 00:16:39 +00:00

Now in libcxx and clang, all the coroutine components are defined in std::experimental namespace. And now the coroutine TS is merged into C++20. So in the working draft like N4892, we could find the coroutine components is defined in std namespace instead of std::experimental namespace. And the coroutine support in clang seems to be relatively stable. So I think it may be suitable to move the coroutine component into the experiment namespace now. This patch would make clang lookup coroutine_traits in std namespace first. For the compatibility consideration, clang would lookup in std::experimental namespace if it can't find definitions in std namespace. So the existing codes wouldn't be break after update compiler. And in case the compiler found std::coroutine_traits and std::experimental::coroutine_traits at the same time, it would emit an error for it. The support for looking up std::experimental::coroutine_traits would be removed in Clang16. Reviewed By: lxfind, Quuxplusone Differential Revision: https://reviews.llvm.org/D108696
42 lines
1.2 KiB
C++
42 lines
1.2 KiB
C++
// RUN: %clang_cc1 -triple x86_64-apple-darwin9 %s -std=c++20 \
|
|
// RUN: -fsyntax-only -Wignored-qualifiers -Wno-error=return-type -verify \
|
|
// RUN: -fblocks -Wno-unreachable-code -Wno-unused-value
|
|
|
|
// RUN: %clang_cc1 -triple x86_64-apple-darwin9 %s -std=c++20 \
|
|
// RUN: -fsyntax-only -Wignored-qualifiers -Wno-error=return-type -verify \
|
|
// RUN: -fblocks -Wno-unreachable-code -Wno-unused-value \
|
|
// RUN: -DDISABLE_WARNING -Wno-coroutine-missing-unhandled-exception
|
|
|
|
#if __has_feature(cxx_exceptions)
|
|
#error This test requires exceptions be disabled
|
|
#endif
|
|
|
|
#include "Inputs/std-coroutine.h"
|
|
|
|
using std::suspend_always;
|
|
using std::suspend_never;
|
|
|
|
#ifndef DISABLE_WARNING
|
|
struct promise_void { // expected-note {{defined here}}
|
|
#else
|
|
struct promise_void {
|
|
#endif
|
|
void get_return_object();
|
|
suspend_always initial_suspend();
|
|
suspend_always final_suspend() noexcept;
|
|
void return_void();
|
|
};
|
|
|
|
template <typename... T>
|
|
struct std::coroutine_traits<void, T...> { using promise_type = promise_void; };
|
|
|
|
#ifndef DISABLE_WARNING
|
|
void test0() { // expected-warning {{'promise_void' is required to declare the member 'unhandled_exception()' when exceptions are enabled}}
|
|
co_return;
|
|
}
|
|
#else
|
|
void test0() { // expected-no-diagnostics
|
|
co_return;
|
|
}
|
|
#endif
|