summaryrefslogtreecommitdiffstats
path: root/clang/lib/Sema
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2011-01-22 22:23:37 +0000
committerAnders Carlsson <andersca@mac.com>2011-01-22 22:23:37 +0000
commit7d59a6833067aa8644217b33fab6bc186f40e43f (patch)
tree80a6ce1d1c283519ced4d01f5b9788f4d4d9e557 /clang/lib/Sema
parentb32c8943e6e03806f81a6e3d7b5a228c89fe746c (diff)
downloadbcm5719-llvm-7d59a6833067aa8644217b33fab6bc186f40e43f.tar.gz
bcm5719-llvm-7d59a6833067aa8644217b33fab6bc186f40e43f.zip
Implement [class.derived]p8.
llvm-svn: 124047
Diffstat (limited to 'clang/lib/Sema')
-rw-r--r--clang/lib/Sema/SemaDeclCXX.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp
index bf5addc34d5..9def74d9543 100644
--- a/clang/lib/Sema/SemaDeclCXX.cpp
+++ b/clang/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
OpenPOWER on IntegriCloud