diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2017-04-21 01:15:13 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2017-04-21 01:15:13 +0000 |
commit | 2195ec9ad4ba7dc363762e3aaf7af93085cb30e1 (patch) | |
tree | fbce0b2f4821e1e0b623bbf40d9bcf4d5b9c080a /clang/test/Modules/Inputs/template-default-args/d.h | |
parent | 49ee2a0f288d8dbec52aa882d7ae583be07edba9 (diff) | |
download | bcm5719-llvm-2195ec9ad4ba7dc363762e3aaf7af93085cb30e1.tar.gz bcm5719-llvm-2195ec9ad4ba7dc363762e3aaf7af93085cb30e1.zip |
[modules] Properly look up the owning module for an instantiation of a merged template.
When looking for the template instantiation pattern of a templated entity,
consistently select the definition of the pattern if there is one. This means
we'll pick the same owning module when we start instantiating a template that
we'll later pick when determining which modules are visible during that
instantiation.
This reinstates r300650, reverted in r300659, with a fix for a regression
reported by Chandler after commit.
llvm-svn: 300938
Diffstat (limited to 'clang/test/Modules/Inputs/template-default-args/d.h')
-rw-r--r-- | clang/test/Modules/Inputs/template-default-args/d.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/clang/test/Modules/Inputs/template-default-args/d.h b/clang/test/Modules/Inputs/template-default-args/d.h index 5961c91a82e..07ececc1f41 100644 --- a/clang/test/Modules/Inputs/template-default-args/d.h +++ b/clang/test/Modules/Inputs/template-default-args/d.h @@ -4,3 +4,10 @@ struct FriendL { template<typename T> friend struct L; }; END + +namespace DeferredLookup { + namespace Indirect { + template<typename, bool = true> struct A {}; + template<typename> struct B { template<typename T> using C = A<T>; }; + } +} |