2012-10-30 06:51:50 +08:00
|
|
|
// RUN: %clang_cc1 -analyze -analyzer-checker=core,alpha.unix.SimpleStream -verify %s
|
|
|
|
|
2012-11-06 12:20:57 +08:00
|
|
|
#include "Inputs/system-header-simulator-for-simple-stream.h"
|
2012-10-30 06:51:50 +08:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
}
|
2012-10-31 10:32:41 +08:00
|
|
|
|
|
|
|
void CloseOnlyOnValidFileHandle() {
|
|
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
|
|
if (F)
|
|
|
|
fclose(F);
|
|
|
|
int x = 0; // no warning
|
|
|
|
}
|
2012-11-03 10:54:20 +08:00
|
|
|
|
|
|
|
void leakOnEnfOfPath1(int *Data) {
|
2012-11-16 03:11:43 +08:00
|
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
|
|
} // expected-warning {{Opened file is never closed; potential resource leak}}
|
2012-11-03 10:54:20 +08:00
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
2012-11-06 12:20:57 +08:00
|
|
|
|
|
|
|
void myfclose(FILE *F);
|
|
|
|
void SymbolEscapedThroughFunctionCall() {
|
|
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
|
|
myfclose(F);
|
|
|
|
return; // no warning
|
|
|
|
}
|
|
|
|
|
|
|
|
FILE *GlobalF;
|
|
|
|
void SymbolEscapedThroughAssignmentToGloabl() {
|
|
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
|
|
GlobalF = F;
|
|
|
|
return; // no warning
|
|
|
|
}
|
|
|
|
|
|
|
|
void SymbolDoesNotEscapeThoughStringAPIs(char *Data) {
|
|
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
|
|
fputc(*Data, F);
|
|
|
|
return; // expected-warning {{Opened file is never closed; potential resource leak}}
|
|
|
|
}
|
2013-02-08 07:05:43 +08:00
|
|
|
|
|
|
|
void passConstPointer(const FILE * F);
|
|
|
|
void testPassConstPointer() {
|
|
|
|
FILE *F = fopen("myfile.txt", "w");
|
|
|
|
passConstPointer(F);
|
|
|
|
return; // expected-warning {{Opened file is never closed; potential resource leak}}
|
|
|
|
}
|
|
|
|
|
|
|
|
void testPassToSystemHeaderFunctionIndirectly() {
|
|
|
|
FileStruct fs;
|
|
|
|
fs.p = fopen("myfile.txt", "w");
|
|
|
|
fakeSystemHeaderCall(&fs);
|
2013-03-21 04:35:57 +08:00
|
|
|
} // expected-warning {{Opened file is never closed; potential resource leak}}
|