mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-19 19:45:40 -04:00

Summary: I agree with https://easyaspi314.github.io/gcc-vs-clang.html?fbclid=IwAR1VA0qxiWVUusOQUv5z7JESS7ZpeJy-UqAI5mnJscofGLqXcqeErIUB2gU, current warning message is not very good. We should try to improve it.. Reviewers: rsmith, aaron.ballman, easyaspi314 Reviewed By: aaron.ballman Subscribers: arphaman, Quuxplusone, mehdi_amini, hiraditya, cfe-commits, llvm-commits Tags: #clang, #llvm Differential Revision: https://reviews.llvm.org/D69762
41 lines
1.1 KiB
C++
41 lines
1.1 KiB
C++
// RUN: %clang_cc1 -std=c++14 -verify %s
|
|
|
|
// pr33561
|
|
class ArrayBuffer;
|
|
template <typename T> class Trans_NS_WTF_RefPtr {
|
|
public:
|
|
ArrayBuffer *operator->() { return nullptr; }
|
|
};
|
|
Trans_NS_WTF_RefPtr<ArrayBuffer> get();
|
|
template <typename _Visitor>
|
|
constexpr void visit(_Visitor __visitor) {
|
|
__visitor(get()); // expected-note {{in instantiation}}
|
|
}
|
|
class ArrayBuffer {
|
|
char data() {
|
|
visit([](auto buffer) -> char { // expected-note {{in instantiation}}
|
|
buffer->data();
|
|
}); // expected-warning {{non-void lambda does not return a value}}
|
|
} // expected-warning {{non-void function does not return a value}}
|
|
};
|
|
|
|
// pr34185
|
|
template <typename Promise> struct coroutine_handle {
|
|
Promise &promise() const { return
|
|
*static_cast<Promise *>(nullptr); // expected-warning {{binding dereferenced null}}
|
|
}
|
|
};
|
|
|
|
template <typename Promise> auto GetCurrenPromise() {
|
|
struct Awaiter { // expected-note {{in instantiation}}
|
|
void await_suspend(coroutine_handle<Promise> h) {
|
|
h.promise(); // expected-note {{in instantiation}}
|
|
}
|
|
};
|
|
return Awaiter{};
|
|
}
|
|
|
|
void foo() {
|
|
auto &&p = GetCurrenPromise<int>(); // expected-note {{in instantiation}}
|
|
}
|