mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 13:56:09 +00:00

specialization with modules enabled. Just don't merge them at all for now; we'll revisit this when support for template merging is added. In passing, make Decl::dump() a little safer to use with PCH/modules, by making it not deserialize any additional declarations. From a debugger you can call decls_begin() or similar first if you want to dump all child decls. llvm-svn: 182544
63 lines
1.0 KiB
C++
63 lines
1.0 KiB
C++
// RUN: %clang_cc1 %s -ast-print -o - -chain-include %s -chain-include %s
|
|
// RUN: %clang_cc1 %s -ast-print -o - -fmodules -chain-include %s -chain-include %s
|
|
|
|
#if !defined(PASS1)
|
|
#define PASS1
|
|
|
|
template <class T> class TClass;
|
|
|
|
namespace NS {
|
|
template <class X, class Y> TClass<X> problematic(X * ptr, const TClass<Y> &src);
|
|
|
|
template <class T>
|
|
class TBaseClass
|
|
{
|
|
protected:
|
|
template <class X, class Y> friend TClass<X> problematic(X * ptr, const TClass<Y> &src);
|
|
};
|
|
}
|
|
|
|
template <class T>
|
|
class TClass: public NS::TBaseClass<T>
|
|
{
|
|
public:
|
|
inline TClass() { }
|
|
};
|
|
|
|
|
|
namespace NS {
|
|
template <class X, class T>
|
|
TClass<X> problematic(X *ptr, const TClass<T> &src);
|
|
}
|
|
|
|
template <class X, class T>
|
|
TClass<X> unconst(const TClass<T> &src);
|
|
|
|
#elif !defined(PASS2)
|
|
#define PASS2
|
|
|
|
namespace std {
|
|
class s {};
|
|
}
|
|
|
|
|
|
typedef TClass<std::s> TStr;
|
|
|
|
struct crash {
|
|
TStr str;
|
|
|
|
crash(const TClass<std::s> p)
|
|
{
|
|
unconst<TStr>(p);
|
|
}
|
|
};
|
|
|
|
#else
|
|
|
|
void f() {
|
|
const TStr p;
|
|
crash c(p);
|
|
}
|
|
|
|
#endif
|