summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/warn-overloaded-virtual.cpp
diff options
context:
space:
mode:
authorAaron Ballman <aaron@aaronballman.com>2014-07-30 23:50:53 +0000
committerAaron Ballman <aaron@aaronballman.com>2014-07-30 23:50:53 +0000
commit04559a79415e813283ddfbb8cdfdde5620c95f3b (patch)
treea7996ad4be61cff0c57b1ce6f4518401f1d0a7af /clang/test/SemaCXX/warn-overloaded-virtual.cpp
parent293cbf6ffe5423353ea53cb8469477e380504a26 (diff)
downloadbcm5719-llvm-04559a79415e813283ddfbb8cdfdde5620c95f3b.tar.gz
bcm5719-llvm-04559a79415e813283ddfbb8cdfdde5620c95f3b.zip
Updating a comment related to the implementation of -Woverloaded-virtual, and adding a FIXME to a test case. (Drive-by removal of trailing whitespace in the test case as well.)
No functional changes. llvm-svn: 214362
Diffstat (limited to 'clang/test/SemaCXX/warn-overloaded-virtual.cpp')
-rw-r--r--clang/test/SemaCXX/warn-overloaded-virtual.cpp22
1 files changed, 20 insertions, 2 deletions
diff --git a/clang/test/SemaCXX/warn-overloaded-virtual.cpp b/clang/test/SemaCXX/warn-overloaded-virtual.cpp
index 629d59dee53..6204826192d 100644
--- a/clang/test/SemaCXX/warn-overloaded-virtual.cpp
+++ b/clang/test/SemaCXX/warn-overloaded-virtual.cpp
@@ -48,8 +48,8 @@ struct Base {
void Base::foo(int) { }
struct Derived : public Base {
- virtual void foo(int);
- void foo(int, int);
+ virtual void foo(int);
+ void foo(int, int);
};
}
@@ -138,3 +138,21 @@ namespace {
// expected-warning@-1{{hides overloaded virtual functions}}
};
}
+
+namespace {
+struct base {
+ void f(char) {}
+};
+
+struct derived : base {
+ void f(int) {}
+};
+
+void foo(derived &d) {
+ d.f('1'); // FIXME: this should warn about calling (anonymous namespace)::derived::f(int)
+ // instead of (anonymous namespace)::base::f(char).
+ // Note: this should be under a new diagnostic flag and eventually moved to a
+ // new test case since it's not strictly related to virtual functions.
+ d.f(12); // This should not warn.
+}
+}
OpenPOWER on IntegriCloud