2010-02-05 10:06:54 +08:00
|
|
|
// RUN: %clang_cc1 -analyzer-check-objc-mem -analyze -analyzer-experimental-internal-checks -analyzer-store=basic -verify %s
|
|
|
|
// RUN: %clang_cc1 -analyzer-check-objc-mem -analyze -analyzer-experimental-internal-checks -analyzer-store=region -verify %s
|
2009-07-11 05:48:10 +08:00
|
|
|
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// This file tests cases where we should not flag out-of-bounds warnings.
|
|
|
|
//===----------------------------------------------------------------------===//
|
2009-05-04 22:31:19 +08:00
|
|
|
|
2009-05-04 03:24:34 +08:00
|
|
|
void f() {
|
|
|
|
long x = 0;
|
|
|
|
char *y = (char*) &x;
|
|
|
|
char c = y[0] + y[1] + y[2]; // no-warning
|
2010-04-01 16:20:27 +08:00
|
|
|
short *z = (short*) &x;
|
|
|
|
short s = z[0] + z[1]; // no-warning
|
2009-05-04 03:24:34 +08:00
|
|
|
}
|
2010-06-26 07:23:04 +08:00
|
|
|
|
|
|
|
void g() {
|
|
|
|
int a[2];
|
|
|
|
char *b = (char*)a;
|
|
|
|
b[3] = 'c'; // no-warning
|
|
|
|
}
|
2010-07-04 08:00:41 +08:00
|
|
|
|
|
|
|
typedef typeof(sizeof(int)) size_t;
|
|
|
|
void *malloc(size_t);
|
|
|
|
void free(void *);
|
|
|
|
|
|
|
|
void field() {
|
|
|
|
struct vec { size_t len; int data[0]; };
|
|
|
|
struct vec *a = malloc(sizeof(struct vec) + 10);
|
|
|
|
a->len = 10;
|
|
|
|
a->data[1] = 5; // no-warning
|
|
|
|
}
|