diff options
author | Anders Carlsson <andersca@mac.com> | 2009-05-13 21:11:42 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-05-13 21:11:42 +0000 |
commit | d8f9cb03ad5ba30094995c254e2b7afcef34d813 (patch) | |
tree | d89b2738ce41211358505efea4c67d8d7f2e34c9 /lib/Sema/SemaAccess.cpp | |
parent | 5dc53c9c2328b5bea5422005b04960c18afd83ad (diff) |
Add a new, more advanced CheckDerivedToBaseConversion that takes custom diagnostic IDs.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@71720 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaAccess.cpp')
-rw-r--r-- | lib/Sema/SemaAccess.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/lib/Sema/SemaAccess.cpp b/lib/Sema/SemaAccess.cpp index b832d38d1d..bae69ac6dc 100644 --- a/lib/Sema/SemaAccess.cpp +++ b/lib/Sema/SemaAccess.cpp @@ -46,7 +46,9 @@ bool Sema::SetMemberAccessSpecifier(NamedDecl *MemberDecl, /// CheckBaseClassAccess - Check that a derived class can access its base class /// and report an error if it can't. [class.access.base] bool Sema::CheckBaseClassAccess(QualType Derived, QualType Base, - BasePaths& Paths, SourceLocation AccessLoc) { + unsigned InaccessibleBaseID, + BasePaths& Paths, SourceLocation AccessLoc, + DeclarationName Name) { Base = Context.getCanonicalType(Base).getUnqualifiedType(); assert(!Paths.isAmbiguous(Base) && "Can't check base class access if set of paths is ambiguous"); @@ -101,8 +103,8 @@ bool Sema::CheckBaseClassAccess(QualType Derived, QualType Base, } if (InacessibleBase) { - Diag(AccessLoc, diag::err_conv_to_inaccessible_base) - << Derived << Base; + Diag(AccessLoc, InaccessibleBaseID) + << Derived << Base << Name; AccessSpecifier AS = InacessibleBase->getAccessSpecifierAsWritten(); |