xref: /aosp_15_r20/external/clang/test/Analysis/NewDelete-custom.cpp (revision 67e74705e28f6214e480b399dd47ea732279e315)
1*67e74705SXin Li // RUN: %clang_cc1 -analyze -analyzer-checker=core,cplusplus.NewDelete,unix.Malloc -std=c++11 -fblocks -verify %s
2*67e74705SXin Li // RUN: %clang_cc1 -analyze -analyzer-checker=core,cplusplus.NewDelete,cplusplus.NewDeleteLeaks,unix.Malloc -std=c++11 -DLEAKS -fblocks -verify %s
3*67e74705SXin Li #include "Inputs/system-header-simulator-cxx.h"
4*67e74705SXin Li 
5*67e74705SXin Li #ifndef LEAKS
6*67e74705SXin Li // expected-no-diagnostics
7*67e74705SXin Li #endif
8*67e74705SXin Li 
9*67e74705SXin Li 
10*67e74705SXin Li void *allocator(std::size_t size);
11*67e74705SXin Li 
operator new[](std::size_t size)12*67e74705SXin Li void *operator new[](std::size_t size) throw() { return allocator(size); }
operator new(std::size_t size)13*67e74705SXin Li void *operator new(std::size_t size) throw() { return allocator(size); }
operator new(std::size_t size,std::nothrow_t & nothrow)14*67e74705SXin Li void *operator new(std::size_t size, std::nothrow_t& nothrow) throw() { return allocator(size); }
15*67e74705SXin Li void *operator new(std::size_t, double d);
16*67e74705SXin Li 
17*67e74705SXin Li class C {
18*67e74705SXin Li public:
19*67e74705SXin Li   void *operator new(std::size_t);
20*67e74705SXin Li };
21*67e74705SXin Li 
testNewMethod()22*67e74705SXin Li void testNewMethod() {
23*67e74705SXin Li   void *p1 = C::operator new(0); // no warn
24*67e74705SXin Li 
25*67e74705SXin Li   C *p2 = new C; // no warn
26*67e74705SXin Li 
27*67e74705SXin Li   C *c3 = ::new C;
28*67e74705SXin Li }
29*67e74705SXin Li #ifdef LEAKS
30*67e74705SXin Li // expected-warning@-2{{Potential leak of memory pointed to by 'c3'}}
31*67e74705SXin Li #endif
32*67e74705SXin Li 
testOpNewArray()33*67e74705SXin Li void testOpNewArray() {
34*67e74705SXin Li   void *p = operator new[](0); // call is inlined, no warn
35*67e74705SXin Li }
36*67e74705SXin Li 
testNewExprArray()37*67e74705SXin Li void testNewExprArray() {
38*67e74705SXin Li   int *p = new int[0];
39*67e74705SXin Li }
40*67e74705SXin Li #ifdef LEAKS
41*67e74705SXin Li // expected-warning@-2{{Potential leak of memory pointed to by 'p'}}
42*67e74705SXin Li #endif
43*67e74705SXin Li 
44*67e74705SXin Li 
45*67e74705SXin Li //----- Custom non-placement operators
testOpNew()46*67e74705SXin Li void testOpNew() {
47*67e74705SXin Li   void *p = operator new(0); // call is inlined, no warn
48*67e74705SXin Li }
49*67e74705SXin Li 
testNewExpr()50*67e74705SXin Li void testNewExpr() {
51*67e74705SXin Li   int *p = new int;
52*67e74705SXin Li }
53*67e74705SXin Li #ifdef LEAKS
54*67e74705SXin Li // expected-warning@-2{{Potential leak of memory pointed to by 'p'}}
55*67e74705SXin Li #endif
56*67e74705SXin Li 
57*67e74705SXin Li 
58*67e74705SXin Li //----- Custom NoThrow placement operators
testOpNewNoThrow()59*67e74705SXin Li void testOpNewNoThrow() {
60*67e74705SXin Li   void *p = operator new(0, std::nothrow);
61*67e74705SXin Li }
62*67e74705SXin Li #ifdef LEAKS
63*67e74705SXin Li // expected-warning@-2{{Potential leak of memory pointed to by 'p'}}
64*67e74705SXin Li #endif
65*67e74705SXin Li 
testNewExprNoThrow()66*67e74705SXin Li void testNewExprNoThrow() {
67*67e74705SXin Li   int *p = new(std::nothrow) int;
68*67e74705SXin Li }
69*67e74705SXin Li #ifdef LEAKS
70*67e74705SXin Li // expected-warning@-2{{Potential leak of memory pointed to by 'p'}}
71*67e74705SXin Li #endif
72*67e74705SXin Li 
73*67e74705SXin Li //----- Custom placement operators
testOpNewPlacement()74*67e74705SXin Li void testOpNewPlacement() {
75*67e74705SXin Li   void *p = operator new(0, 0.1); // no warn
76*67e74705SXin Li }
77*67e74705SXin Li 
testNewExprPlacement()78*67e74705SXin Li void testNewExprPlacement() {
79*67e74705SXin Li   int *p = new(0.1) int; // no warn
80*67e74705SXin Li }
81