fune/tools/clang-tidy/test/clang-analyzer-cplusplus.NewDelete.cpp
Chris Peterson 11ee6d0d0c Bug 1475882 - clang-analyzer: Enable clang-analyzer-cplusplus.NewDelete check. r=andi
Check for double-free, use-after-free and offset problems involving C++ delete. There are currently no clang-analyzer-cplusplus.NewDelete warnings in mozilla-central!

https://clang-analyzer.llvm.org/available_checks.html

MozReview-Commit-ID: 9sVp4fc4JTj

--HG--
extra : rebase_source : 733974ff07b873f6e5cd1e83104f82eafbf7f3c7
extra : source : 778684b276e6658fb9f3fa125aaec984cca8760a
2018-07-14 23:07:40 -07:00

50 lines
1,019 B
C++

// https://clang-analyzer.llvm.org/available_checks.html
void use(int *p);
void test_use_parameter_after_delete(int *p)
{
delete p;
use(p); // warning: use after free
}
class SomeClass {
public:
void f();
};
void test_use_local_after_delete()
{
SomeClass *c = new SomeClass;
delete c;
c->f(); // warning: use after free
}
// XXX clang documentation says this should cause a warning but it doesn't!
void test_delete_alloca()
{
int *p = (int *)__builtin_alloca(sizeof(int));
delete p; // NO warning: deleting memory allocated by alloca
}
void test_double_free()
{
int *p = new int;
delete p;
delete p; // warning: attempt to free released
}
void test_delete_local()
{
int i;
delete &i; // warning: delete address of local
}
// XXX clang documentation says this should cause a warning but it doesn't!
void test_delete_offset()
{
int *p = new int[1];
delete[] (++p);
// NO warning: argument to 'delete[]' is offset by 4 bytes
// from the start of memory allocated by 'new[]'
}