blob: c309349ab3a9e53baf7d557e13494774cfbcd44d [file] [log] [blame]
Daniel Dunbarffd408a2009-03-24 02:24:46 +00001// RUN: clang-cc -analyze -checker-cfref -analyzer-store=basic -verify %s &&
2// RUN: clang-cc -analyze -checker-cfref -analyzer-store=region -verify %s
Ted Kremenek440c9552008-04-30 04:40:48 +00003//
Ted Kremenek83146912009-01-24 06:11:36 +00004// Just exercise the analyzer on code that has at one point caused issues
5// (i.e., no assertions or crashes).
Ted Kremenek440c9552008-04-30 04:40:48 +00006
7
8static const char * f1(const char *x, char *y) {
9 while (*x != 0) {
10 *y++ = *x++;
11 }
12}
Ted Kremenek83146912009-01-24 06:11:36 +000013
14// This following case checks that we properly handle typedefs when getting
15// the RvalueType of an ElementRegion.
16typedef struct F12_struct {} F12_typedef;
17typedef void* void_typedef;
18void_typedef f2_helper();
19static void f2(void *buf) {
20 F12_typedef* x;
21 x = f2_helper();
Douglas Gregor411889e2009-02-13 23:20:09 +000022 memcpy((&x[1]), (buf), 1); // expected-warning{{implicitly declaring C library function 'memcpy' with type 'void *(void *, void const *}} \
23 // expected-note{{please include the header <string.h> or explicitly provide a declaration for 'memcpy'}}
Ted Kremenek83146912009-01-24 06:11:36 +000024}