teak-llvm/clang/test/SemaTemplate/late-parsing-eager-instantiation.cpp
Dávid Bolvanský 1da13237a4 [Diagnostics] Try to improve warning message for -Wreturn-type
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
2019-11-09 17:54:58 +01:00

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}}
}