blob: d10020dc8e66d17bee8247d0100324a8fadb49f2 [file] [log] [blame]
Jordan Rose10ad0812013-04-05 17:55:07 +00001// RUN: %clang_cc1 -analyze -analyzer-checker=core,unix.Malloc,cplusplus.NewDelete -std=c++11 -verify %s
Anton Yartsev6ca45c92014-10-21 12:41:36 +00002// RUN: %clang_cc1 -analyze -analyzer-checker=core,unix.Malloc,cplusplus.NewDelete,cplusplus.NewDeleteLeaks -std=c++11 -verify %s
Anton Yartseve3377fb2013-04-04 23:46:29 +00003
4typedef __typeof(sizeof(int)) size_t;
5void *malloc(size_t);
6void free(void *);
7
8//-------------------------------------------------------------------
Jordan Rose26330562013-04-05 17:55:00 +00009// Check that unix.Malloc + cplusplus.NewDelete does not enable
Anton Yartseve3377fb2013-04-04 23:46:29 +000010// warnings produced by unix.MismatchedDeallocator.
11//-------------------------------------------------------------------
12void testMismatchedDeallocator() {
13 int *p = (int *)malloc(sizeof(int));
14 delete p;
Anna Zaksa1de8562013-04-06 00:41:36 +000015} // expected-warning{{Potential leak of memory pointed to by 'p'}}