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