summaryrefslogtreecommitdiffstats
path: root/clang/test/SemaCXX/warn-unreachable.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2014-03-20 06:44:35 +0000
committerTed Kremenek <kremenek@apple.com>2014-03-20 06:44:35 +0000
commitf5ae0bc671a40126450655c78ade7d8bb36b71c0 (patch)
treee4675afa59dda6829e8dc7e37e82cab071a56c54 /clang/test/SemaCXX/warn-unreachable.cpp
parent798e548955556eef47820910174118abbfa933e3 (diff)
downloadbcm5719-llvm-f5ae0bc671a40126450655c78ade7d8bb36b71c0.tar.gz
bcm5719-llvm-f5ae0bc671a40126450655c78ade7d8bb36b71c0.zip
[-Wunreachable-code] Look through member accesses for 'static const bool' configuration values.
llvm-svn: 204315
Diffstat (limited to 'clang/test/SemaCXX/warn-unreachable.cpp')
-rw-r--r--clang/test/SemaCXX/warn-unreachable.cpp51
1 files changed, 35 insertions, 16 deletions
diff --git a/clang/test/SemaCXX/warn-unreachable.cpp b/clang/test/SemaCXX/warn-unreachable.cpp
index 9db75926d23..7f74732a630 100644
--- a/clang/test/SemaCXX/warn-unreachable.cpp
+++ b/clang/test/SemaCXX/warn-unreachable.cpp
@@ -236,22 +236,41 @@ Frobozz test_return_object_control_flow(int flag) {
void somethingToCall();
- static constexpr bool isConstExprConfigValue() { return true; }
-
- int test_const_expr_config_value() {
- if (isConstExprConfigValue()) {
- somethingToCall();
- return 0;
- }
- somethingToCall(); // no-warning
- return 1;
- }
- int test_const_expr_config_value_2() {
- if (!isConstExprConfigValue()) {
- somethingToCall(); // no-warning
- return 0;
- }
+static constexpr bool isConstExprConfigValue() { return true; }
+
+int test_const_expr_config_value() {
+ if (isConstExprConfigValue()) {
somethingToCall();
- return 1;
+ return 0;
}
+ somethingToCall(); // no-warning
+ return 1;
+}
+int test_const_expr_config_value_2() {
+ if (!isConstExprConfigValue()) {
+ somethingToCall(); // no-warning
+ return 0;
+ }
+ somethingToCall();
+ return 1;
+}
+
+class Frodo {
+public:
+ static const bool aHobbit = true;
+};
+
+void test_static_class_var() {
+ if (Frodo::aHobbit)
+ somethingToCall();
+ else
+ somethingToCall(); // no-warning
+}
+
+void test_static_class_var(Frodo &F) {
+ if (F.aHobbit)
+ somethingToCall();
+ else
+ somethingToCall(); // no-warning
+}
OpenPOWER on IntegriCloud