Training courses
Kernel and Embedded Linux
Bootlin training courses
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
// 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}} } } enum class EnumBool : bool { F = false, T = true }; bool testNoCrashOnSwitchEnumBool(EnumBool E) { switch (E) { case EnumBool::F: return false; } return true; } bool testNoCrashOnSwitchEnumBoolConstant() { EnumBool E = EnumBool::F; switch (E) { case EnumBool::F: return false; } return true; } typedef __INTPTR_TYPE__ intptr_t; bool testNoCrashOnSwitchEnumBoolConstantCastedFromNullptr() { EnumBool E = static_cast<EnumBool>((intptr_t)nullptr); switch (E) { case EnumBool::F: return false; } return true; } bool testNoCrashOnSwitchEnumBoolConstantCastedFromPtr() { int X; intptr_t P = (intptr_t)&X; EnumBool E = static_cast<EnumBool>(P); switch (E) { case EnumBool::F: return false; } return true; }