diff options
author | Alexander Shaposhnikov <shal1t712@gmail.com> | 2017-04-21 01:05:26 +0000 |
---|---|---|
committer | Alexander Shaposhnikov <shal1t712@gmail.com> | 2017-04-21 01:05:26 +0000 |
commit | 015da3534aaa687c47c520a5bc442c15b15b3d01 (patch) | |
tree | e63c0823a75733018d067ba44a6bb7b5866ee7f4 /clang/test/Analysis/enum.cpp | |
parent | e03dc7d7546f8e42fa1dd9688f7003905e5ff2ad (diff) | |
download | bcm5719-llvm-015da3534aaa687c47c520a5bc442c15b15b3d01.tar.gz bcm5719-llvm-015da3534aaa687c47c520a5bc442c15b15b3d01.zip |
[analyzer] Fix assert in ExprEngine::processSwitch
This diff replaces getTypeSize(CondE->getType()))
with getIntWidth(CondE->getType())) in ExprEngine::processSwitch.
These calls are not equivalent for bool, see ASTContext.cpp
Add a test case.
Test plan:
make check-clang-analysis
make check-clang
Differential revision: https://reviews.llvm.org/D32328
llvm-svn: 300936
Diffstat (limited to 'clang/test/Analysis/enum.cpp')
-rw-r--r-- | clang/test/Analysis/enum.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clang/test/Analysis/enum.cpp b/clang/test/Analysis/enum.cpp index e26b8f00d98..b561e65ac86 100644 --- a/clang/test/Analysis/enum.cpp +++ b/clang/test/Analysis/enum.cpp @@ -24,3 +24,16 @@ void testCasting(int i) { clang_analyzer_eval(j == 0); // expected-warning{{FALSE}} } } + +enum class EnumBool : bool { + F = false, + T = true +}; + +bool testNoCrashOnSwitchEnumBool(EnumBool E) { + switch (E) { + case EnumBool::F: + return false; + } + return true; +} |