From: Richard Smith Date: Thu, 11 Jun 2015 23:46:11 +0000 (+0000) Subject: [modules] Fix crash with multiple levels of default template argument merging. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=50c8426bfa30eb6793cd3923d9f4b9058992365a;p=clang [modules] Fix crash with multiple levels of default template argument merging. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@239575 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/AST/DeclTemplate.h b/include/clang/AST/DeclTemplate.h index 26d1e99a05..0fc9b4947d 100644 --- a/include/clang/AST/DeclTemplate.h +++ b/include/clang/AST/DeclTemplate.h @@ -265,7 +265,7 @@ public: const DefaultArgStorage *Storage = this; if (auto *Prev = ValueOrInherited.template dyn_cast()) Storage = &Prev->getDefaultArgStorage(); - if (auto *C = ValueOrInherited.template dyn_cast()) + if (auto *C = Storage->ValueOrInherited.template dyn_cast()) return C->Value; return Storage->ValueOrInherited.template get(); } diff --git a/test/Modules/Inputs/submodules-merge-defs/defs.h b/test/Modules/Inputs/submodules-merge-defs/defs.h index 1ab1d1a005..44259463a1 100644 --- a/test/Modules/Inputs/submodules-merge-defs/defs.h +++ b/test/Modules/Inputs/submodules-merge-defs/defs.h @@ -46,6 +46,7 @@ namespace G { template class K = F> int H(int a = 1); template class K = F> using I = decltype(H()); +template class K = F> struct J {}; namespace NS { struct A {}; diff --git a/test/Modules/submodules-merge-defs.cpp b/test/Modules/submodules-merge-defs.cpp index 6884f56ce7..e7c0ad7f0c 100644 --- a/test/Modules/submodules-merge-defs.cpp +++ b/test/Modules/submodules-merge-defs.cpp @@ -40,6 +40,9 @@ int pre_ff = F().f(); // expected-error +{{must be imported}} int pre_fg = F().g(); // expected-error +{{must be imported}} // expected-note@defs.h:26 +{{here}} +J<> pre_j; // expected-error {{must be imported}} expected-error {{too few}} +// expected-note@defs.h:49 +{{here}} + // Make definitions from second module visible. #ifdef TEXTUAL #include "import-and-redefine.h" @@ -65,3 +68,6 @@ int post_fg = F().g(); // expected-error@-5 {{no matching member function}} // expected-note@defs.h:34 {{substitution failure}} #endif +J<> post_j; +template class K> struct J; +J<> post_j2;