// RUN: %clang_analyze_cc1 -triple x86_64-apple-darwin10 -analyzer-checker=core,debug.ExprInspection -verify -analyzer-config eagerly-assume=false %s
void clang_analyzer_eval(int);
#include "Inputs/system-header-simulator.h"
void use(int);
id foo(int x) {
if (x)
return 0;
static id p = foo(1);
clang_analyzer_eval(p == 0); // expected-warning{{TRUE}}
return p;
}
const int &globalIntRef = 42;
void testGlobalRef() {
// FIXME: Should be TRUE, but should at least not crash.
clang_analyzer_eval(globalIntRef == 42); // expected-warning{{UNKNOWN}}
}
extern int globalInt;
struct IntWrapper {
int value;
};
extern struct IntWrapper globalStruct;
extern void invalidateGlobals();
void testGlobalInvalidation() {
clang_analyzer_eval(globalInt == 42); // expected-warning{{UNKNOWN}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{UNKNOWN}}
if (globalInt != 42)
return;
if (globalStruct.value != 43)
return;
clang_analyzer_eval(globalInt == 42); // expected-warning{{TRUE}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(globalInt == 42); // expected-warning{{UNKNOWN}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{UNKNOWN}}
// Repeat to make sure we don't get the /same/ new symbolic values.
if (globalInt != 42)
return;
if (globalStruct.value != 43)
return;
clang_analyzer_eval(globalInt == 42); // expected-warning{{TRUE}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(globalInt == 42); // expected-warning{{UNKNOWN}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{UNKNOWN}}
}
void testGlobalInvalidationWithDirectBinding() {
clang_analyzer_eval(globalInt == 42); // expected-warning{{UNKNOWN}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{UNKNOWN}}
globalInt = 42;
globalStruct.value = 43;
clang_analyzer_eval(globalInt == 42); // expected-warning{{TRUE}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(globalInt == 42); // expected-warning{{UNKNOWN}}
clang_analyzer_eval(globalStruct.value == 43); // expected-warning{{UNKNOWN}}
}
void testStaticLocals(void) {
static int i;
int tmp;
extern int someSymbolicValue();
i = someSymbolicValue();
if (i == 5) {
clang_analyzer_eval(i == 5); // expected-warning{{TRUE}}
scanf("%d", &tmp);
clang_analyzer_eval(i == 5); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(i == 5); // expected-warning{{TRUE}}
}
i = 6;
clang_analyzer_eval(i == 6); // expected-warning{{TRUE}}
scanf("%d", &tmp);
clang_analyzer_eval(i == 6); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(i == 6); // expected-warning{{TRUE}}
i = someSymbolicValue();
if (i == 7) {
clang_analyzer_eval(i == 7); // expected-warning{{TRUE}}
scanf("%d", &i);
clang_analyzer_eval(i == 7); // expected-warning{{UNKNOWN}}
}
i = 8;
clang_analyzer_eval(i == 8); // expected-warning{{TRUE}}
scanf("%d", &i);
clang_analyzer_eval(i == 8); // expected-warning{{UNKNOWN}}
}
void testNonSystemGlobals(void) {
extern int i;
int tmp;
if (i == 5) {
clang_analyzer_eval(i == 5); // expected-warning{{TRUE}}
scanf("%d", &tmp);
clang_analyzer_eval(i == 5); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(i == 5); // expected-warning{{UNKNOWN}}
}
i = 6;
clang_analyzer_eval(i == 6); // expected-warning{{TRUE}}
scanf("%d", &tmp);
clang_analyzer_eval(i == 6); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(i == 6); // expected-warning{{UNKNOWN}}
if (i == 7) {
clang_analyzer_eval(i == 7); // expected-warning{{TRUE}}
scanf("%d", &i);
clang_analyzer_eval(i == 7); // expected-warning{{UNKNOWN}}
}
i = 8;
clang_analyzer_eval(i == 8); // expected-warning{{TRUE}}
scanf("%d", &i);
clang_analyzer_eval(i == 8); // expected-warning{{UNKNOWN}}
}
void testWrappedGlobals(void) {
extern char c;
SomeStruct s;
if (c == 'C') {
s.p = &c;
clang_analyzer_eval(c == 'C'); // expected-warning{{TRUE}}
fakeSystemHeaderCall(0);
clang_analyzer_eval(c == 'C'); // expected-warning{{TRUE}}
fakeSystemHeaderCall(&s);
clang_analyzer_eval(c == 'C'); // expected-warning{{UNKNOWN}}
}
c = 'c';
s.p = &c;
clang_analyzer_eval(c == 'c'); // expected-warning{{TRUE}}
fakeSystemHeaderCall(0);
clang_analyzer_eval(c == 'c'); // expected-warning{{TRUE}}
fakeSystemHeaderCall(&s);
clang_analyzer_eval(c == 'c'); // expected-warning{{UNKNOWN}}
if (c == 'C') {
s.p = &c;
clang_analyzer_eval(c == 'C'); // expected-warning{{TRUE}}
fakeSystemHeaderCall(0);
clang_analyzer_eval(c == 'C'); // expected-warning{{TRUE}}
fakeSystemHeaderCall(&s);
clang_analyzer_eval(c == 'C'); // expected-warning{{UNKNOWN}}
}
}
void testWrappedStaticsViaGlobal(void) {
static char c;
extern SomeStruct s;
extern char getSomeChar();
c = getSomeChar();
if (c == 'C') {
s.p = &c;
clang_analyzer_eval(c == 'C'); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(c == 'C'); // expected-warning{{UNKNOWN}}
}
c = 'c';
s.p = &c;
clang_analyzer_eval(c == 'c'); // expected-warning{{TRUE}}
invalidateGlobals();
clang_analyzer_eval(c == 'c'); // expected-warning{{UNKNOWN}}
}