mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-25 10:16:07 +00:00

This will simplify checkers that need to register for leaks. Currently, they have to register for both: check dead and check end of path. I've modified the SymbolReaper to consider everything on the stack dead if the input StackLocationContext is 0. (This is a bit disruptive, so I'd like to flash out all the issues asap.) llvm-svn: 167352
66 lines
1.5 KiB
C
66 lines
1.5 KiB
C
// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.unix.SimpleStream -verify %s
|
|
|
|
typedef struct __sFILE {
|
|
unsigned char *_p;
|
|
} FILE;
|
|
FILE *fopen(const char * restrict, const char * restrict) __asm("_" "fopen" );
|
|
int fputc(int, FILE *);
|
|
int fputs(const char * restrict, FILE * restrict) __asm("_" "fputs" );
|
|
int fclose(FILE *);
|
|
void exit(int);
|
|
|
|
void checkDoubleFClose(int *Data) {
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
if (F != 0) {
|
|
fputs ("fopen example", F);
|
|
if (!Data)
|
|
fclose(F);
|
|
else
|
|
fputc(*Data, F);
|
|
fclose(F); // expected-warning {{Closing a previously closed file stream}}
|
|
}
|
|
}
|
|
|
|
int checkLeak(int *Data) {
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
if (F != 0) {
|
|
fputs ("fopen example", F);
|
|
}
|
|
|
|
if (Data) // expected-warning {{Opened file is never closed; potential resource leak}}
|
|
return *Data;
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
void checkLeakFollowedByAssert(int *Data) {
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
if (F != 0) {
|
|
fputs ("fopen example", F);
|
|
if (!Data)
|
|
exit(0);
|
|
fclose(F);
|
|
}
|
|
}
|
|
|
|
void CloseOnlyOnValidFileHandle() {
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
if (F)
|
|
fclose(F);
|
|
int x = 0; // no warning
|
|
}
|
|
|
|
void leakOnEnfOfPath1(int *Data) {
|
|
FILE *F = fopen("myfile.txt", "w");// expected-warning {{Opened file is never closed; potential resource leak}}
|
|
}
|
|
|
|
void leakOnEnfOfPath2(int *Data) {
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
return; // expected-warning {{Opened file is never closed; potential resource leak}}
|
|
}
|
|
|
|
FILE *leakOnEnfOfPath3(int *Data) {
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
return F;
|
|
}
|