Skip to content

Commit

Permalink
[modules] Don't allow use of non-visible (inherited) default template…
Browse files Browse the repository at this point in the history
… arguments.

llvm-svn: 239487
  • Loading branch information
zygoloid committed Jun 10, 2015
1 parent 08829ba commit 95d8395
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 8 deletions.
12 changes: 6 additions & 6 deletions clang/lib/Sema/SemaTemplate.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3299,7 +3299,7 @@ Sema::SubstDefaultTemplateArgumentIfAvailable(TemplateDecl *Template,
HasDefaultArg = false;

if (TemplateTypeParmDecl *TypeParm = dyn_cast<TemplateTypeParmDecl>(Param)) {
if (!TypeParm->hasDefaultArgument())
if (!hasVisibleDefaultArgument(TypeParm))
return TemplateArgumentLoc();

HasDefaultArg = true;
Expand All @@ -3316,7 +3316,7 @@ Sema::SubstDefaultTemplateArgumentIfAvailable(TemplateDecl *Template,

if (NonTypeTemplateParmDecl *NonTypeParm
= dyn_cast<NonTypeTemplateParmDecl>(Param)) {
if (!NonTypeParm->hasDefaultArgument())
if (!hasVisibleDefaultArgument(NonTypeParm))
return TemplateArgumentLoc();

HasDefaultArg = true;
Expand All @@ -3334,7 +3334,7 @@ Sema::SubstDefaultTemplateArgumentIfAvailable(TemplateDecl *Template,

TemplateTemplateParmDecl *TempTempParm
= cast<TemplateTemplateParmDecl>(Param);
if (!TempTempParm->hasDefaultArgument())
if (!hasVisibleDefaultArgument(TempTempParm))
return TemplateArgumentLoc();

HasDefaultArg = true;
Expand Down Expand Up @@ -3799,7 +3799,7 @@ bool Sema::CheckTemplateArgumentList(TemplateDecl *Template,
// (when the template parameter was part of a nested template) into
// the default argument.
if (TemplateTypeParmDecl *TTP = dyn_cast<TemplateTypeParmDecl>(*Param)) {
if (!TTP->hasDefaultArgument())
if (!hasVisibleDefaultArgument(TTP))
return diagnoseArityMismatch(*this, Template, TemplateLoc, NewArgs);

TypeSourceInfo *ArgType = SubstDefaultTemplateArgument(*this,
Expand All @@ -3815,7 +3815,7 @@ bool Sema::CheckTemplateArgumentList(TemplateDecl *Template,
ArgType);
} else if (NonTypeTemplateParmDecl *NTTP
= dyn_cast<NonTypeTemplateParmDecl>(*Param)) {
if (!NTTP->hasDefaultArgument())
if (!hasVisibleDefaultArgument(NTTP))
return diagnoseArityMismatch(*this, Template, TemplateLoc, NewArgs);

ExprResult E = SubstDefaultTemplateArgument(*this, Template,
Expand All @@ -3832,7 +3832,7 @@ bool Sema::CheckTemplateArgumentList(TemplateDecl *Template,
TemplateTemplateParmDecl *TempParm
= cast<TemplateTemplateParmDecl>(*Param);

if (!TempParm->hasDefaultArgument())
if (!hasVisibleDefaultArgument(TempParm))
return diagnoseArityMismatch(*this, Template, TemplateLoc, NewArgs);

NestedNameSpecifierLoc QualifierLoc;
Expand Down
2 changes: 2 additions & 0 deletions clang/test/Modules/Inputs/template-default-args/a.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,3 +3,5 @@ template<typename T> struct B {};
template<typename T> struct C;
template<typename T> struct D;
template<typename T> struct E;
template<typename T = int> struct G;
template<typename T = int> struct H;
6 changes: 4 additions & 2 deletions clang/test/Modules/template-default-args.cpp
Original file line number Diff line number Diff line change
@@ -1,13 +1,12 @@
// RUN: rm -rf %t
// RUN: %clang_cc1 -fmodules -verify -fmodules-cache-path=%t -I %S/Inputs/template-default-args -std=c++11 %s
//
// expected-no-diagnostics

template<typename T> struct A;
template<typename T> struct B;
template<typename T> struct C;
template<typename T = int> struct D;
template<typename T = int> struct E {};
template<typename T> struct H {}; // expected-note {{here}}

#include "b.h"

Expand All @@ -17,6 +16,7 @@ template<typename T = int> struct B;
template<typename T = int> struct C;
template<typename T> struct D {};
template<typename T> struct F {};
template<typename T> struct G {}; // expected-note {{here}}

#include "c.h"

Expand All @@ -26,3 +26,5 @@ extern C<> c;
D<> d;
E<> e;
F<> f;
G<> g; // expected-error {{too few}}
H<> h; // expected-error {{too few}}

0 comments on commit 95d8395

Please sign in to comment.