llvm-capstone/clang/test/PCH/cxx2a-constraints.cpp
Saar Raz 7fb562c1ab [Concepts] Add constraints checks to isSameEntity
isSameEntity was missing constraints checking, causing constrained overloads
to not travel well accross serialization. (bug #45115)

Add constraints checking to isSameEntity.
2020-03-10 22:05:36 +02:00

37 lines
865 B
C++

// RUN: %clang_cc1 -std=c++2a -emit-pch %s -o %t
// RUN: %clang_cc1 -std=c++2a -include-pch %t -verify %s
// expected-no-diagnostics
#ifndef HEADER
#define HEADER
template<typename T, typename U = char>
concept SizedLike = sizeof(T) == sizeof(U);
template <class T> void f(T) requires (sizeof(int) == sizeof(T)) {}
template <class T> void f(T) requires (sizeof(char) == sizeof(T)) {}
template <class T> requires (sizeof(int) == sizeof(T)) void g(T) {}
template <class T> requires (sizeof(char) == sizeof(T)) void g(T) {}
template <SizedLike<int> T> void h(T) {}
template <SizedLike<char> T> void h(T) {}
template <SizedLike<int> T> void i(T) {}
template <SizedLike T> void i(T) {}
#else /*included pch*/
int main() {
(void)f('1');
(void)f(1);
(void)g('1');
(void)g(1);
(void)h('1');
(void)h(1);
(void)i('1');
(void)i(1);
}
#endif // HEADER