diff options
author | Ted Kremenek <kremenek@apple.com> | 2014-03-20 06:44:35 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2014-03-20 06:44:35 +0000 |
commit | f5ae0bc671a40126450655c78ade7d8bb36b71c0 (patch) | |
tree | e4675afa59dda6829e8dc7e37e82cab071a56c54 /clang/test/SemaCXX/warn-unreachable.cpp | |
parent | 798e548955556eef47820910174118abbfa933e3 (diff) | |
download | bcm5719-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.cpp | 51 |
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 +} |