[PATCH] D10935: [Sema] Don't emit "pure virtual" warning for fully qualified calls.
Davide Italiano
dccitaliano at gmail.com
Fri Jul 3 16:12:49 PDT 2015
davide created this revision.
davide added a reviewer: rsmith.
davide added a subscriber: cfe-commits.
Repository:
rL LLVM
http://reviews.llvm.org/D10935
Files:
lib/Sema/SemaOverload.cpp
test/SemaCXX/warn-pure-virtual-call-from-ctor-dtor.cpp
Index: test/SemaCXX/warn-pure-virtual-call-from-ctor-dtor.cpp
===================================================================
--- test/SemaCXX/warn-pure-virtual-call-from-ctor-dtor.cpp
+++ test/SemaCXX/warn-pure-virtual-call-from-ctor-dtor.cpp
@@ -12,3 +12,11 @@
B() { a->f(); };
~B() { a->f(); };
};
+
+// Don't warn if the call is fully qualified. (PR23215)
+struct C {
+ virtual void f() = 0;
+ C() {
+ C::f();
+ }
+};
Index: lib/Sema/SemaOverload.cpp
===================================================================
--- lib/Sema/SemaOverload.cpp
+++ lib/Sema/SemaOverload.cpp
@@ -11788,8 +11788,11 @@
TheCall->getMethodDecl()->isPure()) {
const CXXMethodDecl *MD = TheCall->getMethodDecl();
- if (isa<CXXThisExpr>(MemExpr->getBase()->IgnoreParenCasts())) {
- Diag(MemExpr->getLocStart(),
+ // If the member access is fully qualified, (i.e. X::f), treat
+ // it as a non-virtual call and don't warn.
+ if (isa<CXXThisExpr>(MemExpr->getBase()->IgnoreParenCasts()) &&
+ !(MemExpr->getQualifier())) {
+ Diag(MemExpr->getLocStart(),
diag::warn_call_to_pure_virtual_member_function_from_ctor_dtor)
<< MD->getDeclName() << isa<CXXDestructorDecl>(CurContext)
<< MD->getParent()->getDeclName();
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D10935.29037.patch
Type: text/x-patch
Size: 1293 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20150703/da918dbc/attachment.bin>
More information about the cfe-commits
mailing list