diff options
-rw-r--r-- | lib/AST/Comment.cpp | 4 | ||||
-rw-r--r-- | test/Sema/warn-documentation.cpp | 12 |
2 files changed, 16 insertions, 0 deletions
diff --git a/lib/AST/Comment.cpp b/lib/AST/Comment.cpp index 15b80c6455..ecf6d2a553 100644 --- a/lib/AST/Comment.cpp +++ b/lib/AST/Comment.cpp @@ -194,6 +194,10 @@ void DeclInfo::fill() { } else if (isa<ClassTemplateSpecializationDecl>(ThisDecl)) { IsTemplateDecl = true; IsTemplateSpecialization = true; + } else if (const TypeAliasTemplateDecl *TAT = + dyn_cast<TypeAliasTemplateDecl>(ThisDecl)) { + IsTemplateDecl = true; + TemplateParameters = TAT->getTemplateParameters(); } IsFilled = true; } diff --git a/test/Sema/warn-documentation.cpp b/test/Sema/warn-documentation.cpp index b31e480db8..44d24440f0 100644 --- a/test/Sema/warn-documentation.cpp +++ b/test/Sema/warn-documentation.cpp @@ -250,6 +250,18 @@ void test_tparam11(); template<int I> void test_tparam12(); +template<typename T, typename U> +class test_tparam13 { }; + +/// \tparam T Aaa +template<typename T> +using test_tparam14 = test_tparam13<T, int>; + +// expected-warning@+1 {{template parameter 'U' not found in the template declaration}} expected-note@+1 {{did you mean 'T'?}} +/// \tparam U Aaa +template<typename T> +using test_tparam15 = test_tparam13<T, int>; + // expected-warning@+1 {{empty paragraph passed to '\brief' command}} int test1; ///< \brief\brief Aaa |