36 lines
1.2 KiB
C++
36 lines
1.2 KiB
C++
|
// RUN: %clang_cc1 -std=c++14 -fmodules %s -verify
|
||
|
// RUN: %clang_cc1 -std=c++14 -fmodules %s -verify -triple i686-windows
|
||
|
// expected-no-diagnostics
|
||
|
#pragma clang module build A
|
||
|
module A {}
|
||
|
#pragma clang module contents
|
||
|
#pragma clang module begin A
|
||
|
template<typename T> struct ct { friend auto operator-(ct, ct) { struct X {}; return X(); } void x(); };
|
||
|
#pragma clang module end
|
||
|
#pragma clang module endbuild
|
||
|
|
||
|
#pragma clang module build B
|
||
|
module B {}
|
||
|
#pragma clang module contents
|
||
|
#pragma clang module begin B
|
||
|
template<typename T> struct ct { friend auto operator-(ct, ct) { struct X{}; return X(); } void x(); };
|
||
|
inline auto f() { return ct<float>() - ct<float>(); }
|
||
|
#pragma clang module end
|
||
|
#pragma clang module endbuild
|
||
|
|
||
|
// Force the definition of ct in module A to be the primary definition.
|
||
|
#pragma clang module import A
|
||
|
template<typename T> void ct<T>::x() {}
|
||
|
|
||
|
// Attempt to cause the definition of operator- in the ct primary template in
|
||
|
// module B to be the primary definition of that function. If that happens,
|
||
|
// we'll be left with a class template ct that appears to not contain a
|
||
|
// definition of the inline friend function.
|
||
|
#pragma clang module import B
|
||
|
auto v = f();
|
||
|
|
||
|
ct<int> make();
|
||
|
void h() {
|
||
|
make() - make();
|
||
|
}
|