mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-24 22:08:57 -04:00

Summary: Replace calls to %clang/%clang_cc1 with %clang_analyze_cc1 when invoking static analyzer, and perform runtime substitution to select the appropriate constraint manager, per D28952. Reviewers: xazax.hun, NoQ, zaks.anna, dcoughlin Subscribers: mgorny, rgov, mikhail.ramalho, a.sidorin, cfe-commits Differential Revision: https://reviews.llvm.org/D30373 llvm-svn: 296837
27 lines
601 B
C++
27 lines
601 B
C++
// RUN: %clang_analyze_cc1 -std=c++11 -analyzer-checker=debug.ExprInspection %s
|
|
|
|
void clang_analyzer_eval(bool);
|
|
|
|
enum class Foo {
|
|
Zero
|
|
};
|
|
|
|
bool pr15703(int x) {
|
|
return Foo::Zero == (Foo)x; // don't crash
|
|
}
|
|
|
|
void testCasting(int i) {
|
|
Foo f = static_cast<Foo>(i);
|
|
int j = static_cast<int>(f);
|
|
if (i == 0)
|
|
{
|
|
clang_analyzer_eval(f == Foo::Zero); // expected-warning{{TRUE}}
|
|
clang_analyzer_eval(j == 0); // expected-warning{{TRUE}}
|
|
}
|
|
else
|
|
{
|
|
clang_analyzer_eval(f == Foo::Zero); // expected-warning{{FALSE}}
|
|
clang_analyzer_eval(j == 0); // expected-warning{{FALSE}}
|
|
}
|
|
}
|