diff options
author | Anders Carlsson <andersca@mac.com> | 2011-01-22 22:23:37 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2011-01-22 22:23:37 +0000 |
commit | aa23d288be658cca59d2e128954a50e9ada4ef27 (patch) | |
tree | 39a6384a3f19e2939981db2163dbb3ea6098ea57 /lib/Sema/SemaDeclCXX.cpp | |
parent | faa6afd3e25688dc4e56c970ad57c0c31f2beeed (diff) |
Implement [class.derived]p8.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@124047 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaDeclCXX.cpp')
-rw-r--r-- | lib/Sema/SemaDeclCXX.cpp | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/lib/Sema/SemaDeclCXX.cpp b/lib/Sema/SemaDeclCXX.cpp index bf5addc34d..9def74d954 100644 --- a/lib/Sema/SemaDeclCXX.cpp +++ b/lib/Sema/SemaDeclCXX.cpp @@ -886,6 +886,26 @@ void Sema::CheckOverrideControl(const Decl *D) { << MD->getDeclName(); return; } + + // C++0x [class.derived]p8: + // In a class definition marked with the class-virt-specifier explicit, + // if a virtual member function that is neither implicitly-declared nor a + // destructor overrides a member function of a base class and it is not + // marked with the virt-specifier override, the program is ill-formed. + if (MD->getParent()->isMarkedExplicit() && !isa<CXXDestructorDecl>(MD) && + HasOverriddenMethods && !MD->isMarkedOverride()) { + llvm::SmallVector<const CXXMethodDecl*, 4> + OverriddenMethods(MD->begin_overridden_methods(), + MD->end_overridden_methods()); + + Diag(MD->getLocation(), diag::err_function_overriding_without_override) + << MD->getDeclName() + << (unsigned)OverriddenMethods.size(); + + for (unsigned I = 0; I != OverriddenMethods.size(); ++I) + Diag(OverriddenMethods[I]->getLocation(), + diag::note_overridden_virtual_function); + } } /// CheckIfOverriddenFunctionIsMarkedFinal - Checks whether a virtual member |