diff options
author | Douglas Gregor <dgregor@apple.com> | 2012-03-30 16:20:47 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2012-03-30 16:20:47 +0000 |
commit | 8b0fa5241a0416fc50dfbb7e38f20e777f191848 (patch) | |
tree | 1bce1e1579e3837bc13d69a9d807b6614c9b50ef /lib/Sema/SemaTemplate.cpp | |
parent | 49d26d2817180ccde605c987f79cd3a5b57639cd (diff) |
If we encounter a friend class template for which we cannot resolve
the nested-name-specifier (e.g., because it is dependent), do not
error even though we can't represent it in the AST at this point.
This is a horrible, horrible hack. The actual feature we still need to
implement (for C++98!) is covered by PR12292. However, we used to
silently accept this code, so when we recently started rejecting it we
caused some regressions (e.g., <rdar://problem/11147355>). This hack
brings us back to the passable-but-not-good state we had previously.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@153752 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaTemplate.cpp')
-rw-r--r-- | lib/Sema/SemaTemplate.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/Sema/SemaTemplate.cpp b/lib/Sema/SemaTemplate.cpp index 34e5d722ca..ec11f8d224 100644 --- a/lib/Sema/SemaTemplate.cpp +++ b/lib/Sema/SemaTemplate.cpp @@ -872,8 +872,12 @@ Sema::CheckClassTemplate(Scope *S, unsigned TagSpec, TagUseKind TUK, if (SS.isNotEmpty() && !SS.isInvalid()) { SemanticContext = computeDeclContext(SS, true); if (!SemanticContext) { - Diag(NameLoc, diag::err_template_qualified_declarator_no_match) - << SS.getScopeRep() << SS.getRange(); + // FIXME: Horrible, horrible hack! We can't currently represent this + // in the AST, and historically we have just ignored such friend + // class templates, so don't complain here. + if (TUK != TUK_Friend) + Diag(NameLoc, diag::err_template_qualified_declarator_no_match) + << SS.getScopeRep() << SS.getRange(); return true; } |