blob: b420551c3e9a9df9940312da05054dc31f10d13f [file] [log] [blame]
Jordan Rose10ad0812013-04-05 17:55:07 +00001// RUN: %clang_cc1 -analyze -analyzer-checker=cplusplus.NewDelete,unix.Malloc -analyzer-output=text -verify %s
Jordan Rose5e2b3a32013-06-03 23:00:19 +00002// RUN: %clang_cc1 -analyze -analyzer-checker=cplusplus.NewDelete,unix.Malloc -analyzer-output=plist -analyzer-config path-diagnostics-alternate=false %s -o %t.plist
Anton Yartsev13df0362013-03-25 01:35:45 +00003// RUN: FileCheck --input-file=%t.plist %s
4
5void test() {
6 int *p = new int;
7 // expected-note@-1 {{Memory is allocated}}
8 if (p)
Pavel Labathfce1b032013-08-28 08:04:08 +00009 // expected-note@-1 {{Taking true branch}}
Anton Yartsev13df0362013-03-25 01:35:45 +000010 delete p;
11 // expected-note@-1 {{Memory is released}}
12
13 delete p; // expected-warning {{Attempt to free released memory}}
14 // expected-note@-1 {{Attempt to free released memory}}
15}
16
Anna Zakse4cfcd42013-04-16 00:22:55 +000017struct Odd {
18 void kill() {
19 delete this; // expected-note {{Memory is released}}
20 }
21};
22
23void test(Odd *odd) {
24 odd->kill(); // expected-note{{Calling 'Odd::kill'}}
25 // expected-note@-1 {{Returning; memory was released}}
26 delete odd; // expected-warning {{Attempt to free released memory}}
27 // expected-note@-1 {{Attempt to free released memory}}
28}
29
Anton Yartsev13df0362013-03-25 01:35:45 +000030// CHECK: <key>diagnostics</key>
Anton Yartsev13df0362013-03-25 01:35:45 +000031// CHECK-NEXT: <array>
32// CHECK-NEXT: <dict>
Anna Zakse4cfcd42013-04-16 00:22:55 +000033// CHECK-NEXT: <key>path</key>
34// CHECK-NEXT: <array>
35// CHECK-NEXT: <dict>
36// CHECK-NEXT: <key>kind</key><string>control</string>
37// CHECK-NEXT: <key>edges</key>
38// CHECK-NEXT: <array>
39// CHECK-NEXT: <dict>
40// CHECK-NEXT: <key>start</key>
41// CHECK-NEXT: <array>
42// CHECK-NEXT: <dict>
43// CHECK-NEXT: <key>line</key><integer>6</integer>
44// CHECK-NEXT: <key>col</key><integer>3</integer>
45// CHECK-NEXT: <key>file</key><integer>0</integer>
46// CHECK-NEXT: </dict>
47// CHECK-NEXT: <dict>
48// CHECK-NEXT: <key>line</key><integer>6</integer>
49// CHECK-NEXT: <key>col</key><integer>5</integer>
50// CHECK-NEXT: <key>file</key><integer>0</integer>
51// CHECK-NEXT: </dict>
52// CHECK-NEXT: </array>
53// CHECK-NEXT: <key>end</key>
54// CHECK-NEXT: <array>
55// CHECK-NEXT: <dict>
56// CHECK-NEXT: <key>line</key><integer>6</integer>
57// CHECK-NEXT: <key>col</key><integer>12</integer>
58// CHECK-NEXT: <key>file</key><integer>0</integer>
59// CHECK-NEXT: </dict>
60// CHECK-NEXT: <dict>
61// CHECK-NEXT: <key>line</key><integer>6</integer>
62// CHECK-NEXT: <key>col</key><integer>14</integer>
63// CHECK-NEXT: <key>file</key><integer>0</integer>
64// CHECK-NEXT: </dict>
65// CHECK-NEXT: </array>
66// CHECK-NEXT: </dict>
67// CHECK-NEXT: </array>
68// CHECK-NEXT: </dict>
69// CHECK-NEXT: <dict>
70// CHECK-NEXT: <key>kind</key><string>event</string>
71// CHECK-NEXT: <key>location</key>
Anton Yartsev13df0362013-03-25 01:35:45 +000072// CHECK-NEXT: <dict>
Anna Zakse4cfcd42013-04-16 00:22:55 +000073// CHECK-NEXT: <key>line</key><integer>6</integer>
74// CHECK-NEXT: <key>col</key><integer>12</integer>
75// CHECK-NEXT: <key>file</key><integer>0</integer>
76// CHECK-NEXT: </dict>
77// CHECK-NEXT: <key>ranges</key>
78// CHECK-NEXT: <array>
Anton Yartsev13df0362013-03-25 01:35:45 +000079// CHECK-NEXT: <array>
80// CHECK-NEXT: <dict>
81// CHECK-NEXT: <key>line</key><integer>6</integer>
82// CHECK-NEXT: <key>col</key><integer>12</integer>
83// CHECK-NEXT: <key>file</key><integer>0</integer>
84// CHECK-NEXT: </dict>
85// CHECK-NEXT: <dict>
86// CHECK-NEXT: <key>line</key><integer>6</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +000087// CHECK-NEXT: <key>col</key><integer>18</integer>
Anton Yartsev13df0362013-03-25 01:35:45 +000088// CHECK-NEXT: <key>file</key><integer>0</integer>
89// CHECK-NEXT: </dict>
90// CHECK-NEXT: </array>
Anton Yartsev13df0362013-03-25 01:35:45 +000091// CHECK-NEXT: </array>
Anna Zakse4cfcd42013-04-16 00:22:55 +000092// CHECK-NEXT: <key>depth</key><integer>0</integer>
93// CHECK-NEXT: <key>extended_message</key>
94// CHECK-NEXT: <string>Memory is allocated</string>
95// CHECK-NEXT: <key>message</key>
96// CHECK-NEXT: <string>Memory is allocated</string>
97// CHECK-NEXT: </dict>
98// CHECK-NEXT: <dict>
99// CHECK-NEXT: <key>kind</key><string>control</string>
100// CHECK-NEXT: <key>edges</key>
101// CHECK-NEXT: <array>
102// CHECK-NEXT: <dict>
103// CHECK-NEXT: <key>start</key>
104// CHECK-NEXT: <array>
105// CHECK-NEXT: <dict>
106// CHECK-NEXT: <key>line</key><integer>6</integer>
107// CHECK-NEXT: <key>col</key><integer>12</integer>
108// CHECK-NEXT: <key>file</key><integer>0</integer>
109// CHECK-NEXT: </dict>
110// CHECK-NEXT: <dict>
111// CHECK-NEXT: <key>line</key><integer>6</integer>
112// CHECK-NEXT: <key>col</key><integer>14</integer>
113// CHECK-NEXT: <key>file</key><integer>0</integer>
114// CHECK-NEXT: </dict>
115// CHECK-NEXT: </array>
116// CHECK-NEXT: <key>end</key>
117// CHECK-NEXT: <array>
118// CHECK-NEXT: <dict>
119// CHECK-NEXT: <key>line</key><integer>8</integer>
120// CHECK-NEXT: <key>col</key><integer>3</integer>
121// CHECK-NEXT: <key>file</key><integer>0</integer>
122// CHECK-NEXT: </dict>
123// CHECK-NEXT: <dict>
124// CHECK-NEXT: <key>line</key><integer>8</integer>
125// CHECK-NEXT: <key>col</key><integer>4</integer>
126// CHECK-NEXT: <key>file</key><integer>0</integer>
127// CHECK-NEXT: </dict>
128// CHECK-NEXT: </array>
129// CHECK-NEXT: </dict>
130// CHECK-NEXT: </array>
131// CHECK-NEXT: </dict>
132// CHECK-NEXT: <dict>
133// CHECK-NEXT: <key>kind</key><string>control</string>
134// CHECK-NEXT: <key>edges</key>
135// CHECK-NEXT: <array>
136// CHECK-NEXT: <dict>
137// CHECK-NEXT: <key>start</key>
138// CHECK-NEXT: <array>
139// CHECK-NEXT: <dict>
140// CHECK-NEXT: <key>line</key><integer>8</integer>
141// CHECK-NEXT: <key>col</key><integer>3</integer>
142// CHECK-NEXT: <key>file</key><integer>0</integer>
143// CHECK-NEXT: </dict>
144// CHECK-NEXT: <dict>
145// CHECK-NEXT: <key>line</key><integer>8</integer>
146// CHECK-NEXT: <key>col</key><integer>4</integer>
147// CHECK-NEXT: <key>file</key><integer>0</integer>
148// CHECK-NEXT: </dict>
149// CHECK-NEXT: </array>
150// CHECK-NEXT: <key>end</key>
151// CHECK-NEXT: <array>
152// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000153// CHECK-NEXT: <key>line</key><integer>10</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000154// CHECK-NEXT: <key>col</key><integer>5</integer>
155// CHECK-NEXT: <key>file</key><integer>0</integer>
156// CHECK-NEXT: </dict>
157// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000158// CHECK-NEXT: <key>line</key><integer>10</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000159// CHECK-NEXT: <key>col</key><integer>10</integer>
160// CHECK-NEXT: <key>file</key><integer>0</integer>
161// CHECK-NEXT: </dict>
162// CHECK-NEXT: </array>
163// CHECK-NEXT: </dict>
164// CHECK-NEXT: </array>
165// CHECK-NEXT: </dict>
166// CHECK-NEXT: <dict>
167// CHECK-NEXT: <key>kind</key><string>event</string>
168// CHECK-NEXT: <key>location</key>
169// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000170// CHECK-NEXT: <key>line</key><integer>10</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000171// CHECK-NEXT: <key>col</key><integer>5</integer>
172// CHECK-NEXT: <key>file</key><integer>0</integer>
173// CHECK-NEXT: </dict>
174// CHECK-NEXT: <key>ranges</key>
175// CHECK-NEXT: <array>
176// CHECK-NEXT: <array>
177// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000178// CHECK-NEXT: <key>line</key><integer>10</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000179// CHECK-NEXT: <key>col</key><integer>5</integer>
180// CHECK-NEXT: <key>file</key><integer>0</integer>
181// CHECK-NEXT: </dict>
182// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000183// CHECK-NEXT: <key>line</key><integer>10</integer>
Anton Yartsev13df0362013-03-25 01:35:45 +0000184// CHECK-NEXT: <key>col</key><integer>12</integer>
185// CHECK-NEXT: <key>file</key><integer>0</integer>
186// CHECK-NEXT: </dict>
Anton Yartsev13df0362013-03-25 01:35:45 +0000187// CHECK-NEXT: </array>
Anton Yartsev13df0362013-03-25 01:35:45 +0000188// CHECK-NEXT: </array>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000189// CHECK-NEXT: <key>depth</key><integer>0</integer>
190// CHECK-NEXT: <key>extended_message</key>
191// CHECK-NEXT: <string>Memory is released</string>
192// CHECK-NEXT: <key>message</key>
193// CHECK-NEXT: <string>Memory is released</string>
194// CHECK-NEXT: </dict>
195// CHECK-NEXT: <dict>
196// CHECK-NEXT: <key>kind</key><string>control</string>
197// CHECK-NEXT: <key>edges</key>
198// CHECK-NEXT: <array>
199// CHECK-NEXT: <dict>
200// CHECK-NEXT: <key>start</key>
201// CHECK-NEXT: <array>
202// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000203// CHECK-NEXT: <key>line</key><integer>10</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000204// CHECK-NEXT: <key>col</key><integer>5</integer>
205// CHECK-NEXT: <key>file</key><integer>0</integer>
206// CHECK-NEXT: </dict>
207// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000208// CHECK-NEXT: <key>line</key><integer>10</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000209// CHECK-NEXT: <key>col</key><integer>10</integer>
210// CHECK-NEXT: <key>file</key><integer>0</integer>
211// CHECK-NEXT: </dict>
212// CHECK-NEXT: </array>
213// CHECK-NEXT: <key>end</key>
214// CHECK-NEXT: <array>
215// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000216// CHECK-NEXT: <key>line</key><integer>13</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000217// CHECK-NEXT: <key>col</key><integer>3</integer>
218// CHECK-NEXT: <key>file</key><integer>0</integer>
219// CHECK-NEXT: </dict>
220// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000221// CHECK-NEXT: <key>line</key><integer>13</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000222// CHECK-NEXT: <key>col</key><integer>8</integer>
223// CHECK-NEXT: <key>file</key><integer>0</integer>
224// CHECK-NEXT: </dict>
225// CHECK-NEXT: </array>
226// CHECK-NEXT: </dict>
227// CHECK-NEXT: </array>
228// CHECK-NEXT: </dict>
229// CHECK-NEXT: <dict>
230// CHECK-NEXT: <key>kind</key><string>event</string>
231// CHECK-NEXT: <key>location</key>
Anton Yartsev13df0362013-03-25 01:35:45 +0000232// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000233// CHECK-NEXT: <key>line</key><integer>13</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000234// CHECK-NEXT: <key>col</key><integer>3</integer>
235// CHECK-NEXT: <key>file</key><integer>0</integer>
Anton Yartsev13df0362013-03-25 01:35:45 +0000236// CHECK-NEXT: </dict>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000237// CHECK-NEXT: <key>ranges</key>
Anton Yartsev13df0362013-03-25 01:35:45 +0000238// CHECK-NEXT: <array>
Anton Yartsev13df0362013-03-25 01:35:45 +0000239// CHECK-NEXT: <array>
240// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000241// CHECK-NEXT: <key>line</key><integer>13</integer>
Anton Yartsev13df0362013-03-25 01:35:45 +0000242// CHECK-NEXT: <key>col</key><integer>3</integer>
243// CHECK-NEXT: <key>file</key><integer>0</integer>
244// CHECK-NEXT: </dict>
245// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000246// CHECK-NEXT: <key>line</key><integer>13</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000247// CHECK-NEXT: <key>col</key><integer>10</integer>
Anton Yartsev13df0362013-03-25 01:35:45 +0000248// CHECK-NEXT: <key>file</key><integer>0</integer>
249// CHECK-NEXT: </dict>
250// CHECK-NEXT: </array>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000251// CHECK-NEXT: </array>
252// CHECK-NEXT: <key>depth</key><integer>0</integer>
253// CHECK-NEXT: <key>extended_message</key>
254// CHECK-NEXT: <string>Attempt to free released memory</string>
255// CHECK-NEXT: <key>message</key>
256// CHECK-NEXT: <string>Attempt to free released memory</string>
257// CHECK-NEXT: </dict>
258// CHECK-NEXT: </array>
259// CHECK-NEXT: <key>description</key><string>Attempt to free released memory</string>
260// CHECK-NEXT: <key>category</key><string>Memory Error</string>
261// CHECK-NEXT: <key>type</key><string>Double free</string>
262// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
263// CHECK-NEXT: <key>issue_context</key><string>test</string>
Pavel Labathfce1b032013-08-28 08:04:08 +0000264// CHECK-NEXT: <key>issue_hash</key><string>8</string>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000265// CHECK-NEXT: <key>location</key>
266// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000267// CHECK-NEXT: <key>line</key><integer>13</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000268// CHECK-NEXT: <key>col</key><integer>3</integer>
269// CHECK-NEXT: <key>file</key><integer>0</integer>
270// CHECK-NEXT: </dict>
Anton Yartsev13df0362013-03-25 01:35:45 +0000271// CHECK-NEXT: </dict>
272// CHECK-NEXT: <dict>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000273// CHECK-NEXT: <key>path</key>
Anton Yartsev13df0362013-03-25 01:35:45 +0000274// CHECK-NEXT: <array>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000275// CHECK-NEXT: <dict>
276// CHECK-NEXT: <key>kind</key><string>event</string>
277// CHECK-NEXT: <key>location</key>
278// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000279// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000280// CHECK-NEXT: <key>col</key><integer>2</integer>
281// CHECK-NEXT: <key>file</key><integer>0</integer>
282// CHECK-NEXT: </dict>
283// CHECK-NEXT: <key>ranges</key>
Anton Yartsev13df0362013-03-25 01:35:45 +0000284// CHECK-NEXT: <array>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000285// CHECK-NEXT: <array>
286// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000287// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000288// CHECK-NEXT: <key>col</key><integer>2</integer>
289// CHECK-NEXT: <key>file</key><integer>0</integer>
290// CHECK-NEXT: </dict>
291// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000292// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000293// CHECK-NEXT: <key>col</key><integer>12</integer>
294// CHECK-NEXT: <key>file</key><integer>0</integer>
295// CHECK-NEXT: </dict>
296// CHECK-NEXT: </array>
Anton Yartsev13df0362013-03-25 01:35:45 +0000297// CHECK-NEXT: </array>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000298// CHECK-NEXT: <key>depth</key><integer>0</integer>
299// CHECK-NEXT: <key>extended_message</key>
300// CHECK-NEXT: <string>Calling &apos;Odd::kill&apos;</string>
301// CHECK-NEXT: <key>message</key>
302// CHECK-NEXT: <string>Calling &apos;Odd::kill&apos;</string>
303// CHECK-NEXT: </dict>
304// CHECK-NEXT: <dict>
305// CHECK-NEXT: <key>kind</key><string>event</string>
306// CHECK-NEXT: <key>location</key>
307// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000308// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000309// CHECK-NEXT: <key>col</key><integer>2</integer>
310// CHECK-NEXT: <key>file</key><integer>0</integer>
311// CHECK-NEXT: </dict>
312// CHECK-NEXT: <key>depth</key><integer>1</integer>
313// CHECK-NEXT: <key>extended_message</key>
314// CHECK-NEXT: <string>Entered call from &apos;test&apos;</string>
315// CHECK-NEXT: <key>message</key>
316// CHECK-NEXT: <string>Entered call from &apos;test&apos;</string>
317// CHECK-NEXT: </dict>
318// CHECK-NEXT: <dict>
319// CHECK-NEXT: <key>kind</key><string>control</string>
320// CHECK-NEXT: <key>edges</key>
321// CHECK-NEXT: <array>
322// CHECK-NEXT: <dict>
323// CHECK-NEXT: <key>start</key>
324// CHECK-NEXT: <array>
325// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000326// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000327// CHECK-NEXT: <key>col</key><integer>2</integer>
328// CHECK-NEXT: <key>file</key><integer>0</integer>
329// CHECK-NEXT: </dict>
330// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000331// CHECK-NEXT: <key>line</key><integer>18</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000332// CHECK-NEXT: <key>col</key><integer>5</integer>
333// CHECK-NEXT: <key>file</key><integer>0</integer>
334// CHECK-NEXT: </dict>
335// CHECK-NEXT: </array>
336// CHECK-NEXT: <key>end</key>
337// CHECK-NEXT: <array>
338// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000339// CHECK-NEXT: <key>line</key><integer>19</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000340// CHECK-NEXT: <key>col</key><integer>3</integer>
341// CHECK-NEXT: <key>file</key><integer>0</integer>
342// CHECK-NEXT: </dict>
343// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000344// CHECK-NEXT: <key>line</key><integer>19</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000345// CHECK-NEXT: <key>col</key><integer>8</integer>
346// CHECK-NEXT: <key>file</key><integer>0</integer>
347// CHECK-NEXT: </dict>
348// CHECK-NEXT: </array>
349// CHECK-NEXT: </dict>
350// CHECK-NEXT: </array>
351// CHECK-NEXT: </dict>
352// CHECK-NEXT: <dict>
353// CHECK-NEXT: <key>kind</key><string>event</string>
354// CHECK-NEXT: <key>location</key>
355// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000356// CHECK-NEXT: <key>line</key><integer>19</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000357// CHECK-NEXT: <key>col</key><integer>3</integer>
358// CHECK-NEXT: <key>file</key><integer>0</integer>
359// CHECK-NEXT: </dict>
360// CHECK-NEXT: <key>ranges</key>
361// CHECK-NEXT: <array>
362// CHECK-NEXT: <array>
363// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000364// CHECK-NEXT: <key>line</key><integer>19</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000365// CHECK-NEXT: <key>col</key><integer>3</integer>
366// CHECK-NEXT: <key>file</key><integer>0</integer>
367// CHECK-NEXT: </dict>
368// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000369// CHECK-NEXT: <key>line</key><integer>19</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000370// CHECK-NEXT: <key>col</key><integer>13</integer>
371// CHECK-NEXT: <key>file</key><integer>0</integer>
372// CHECK-NEXT: </dict>
373// CHECK-NEXT: </array>
374// CHECK-NEXT: </array>
375// CHECK-NEXT: <key>depth</key><integer>1</integer>
376// CHECK-NEXT: <key>extended_message</key>
377// CHECK-NEXT: <string>Memory is released</string>
378// CHECK-NEXT: <key>message</key>
379// CHECK-NEXT: <string>Memory is released</string>
380// CHECK-NEXT: </dict>
381// CHECK-NEXT: <dict>
382// CHECK-NEXT: <key>kind</key><string>event</string>
383// CHECK-NEXT: <key>location</key>
384// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000385// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000386// CHECK-NEXT: <key>col</key><integer>2</integer>
387// CHECK-NEXT: <key>file</key><integer>0</integer>
388// CHECK-NEXT: </dict>
389// CHECK-NEXT: <key>ranges</key>
390// CHECK-NEXT: <array>
391// CHECK-NEXT: <array>
392// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000393// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000394// CHECK-NEXT: <key>col</key><integer>2</integer>
395// CHECK-NEXT: <key>file</key><integer>0</integer>
396// CHECK-NEXT: </dict>
397// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000398// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000399// CHECK-NEXT: <key>col</key><integer>12</integer>
400// CHECK-NEXT: <key>file</key><integer>0</integer>
401// CHECK-NEXT: </dict>
402// CHECK-NEXT: </array>
403// CHECK-NEXT: </array>
404// CHECK-NEXT: <key>depth</key><integer>0</integer>
405// CHECK-NEXT: <key>extended_message</key>
406// CHECK-NEXT: <string>Returning; memory was released</string>
407// CHECK-NEXT: <key>message</key>
408// CHECK-NEXT: <string>Returning; memory was released</string>
409// CHECK-NEXT: </dict>
410// CHECK-NEXT: <dict>
411// CHECK-NEXT: <key>kind</key><string>control</string>
412// CHECK-NEXT: <key>edges</key>
413// CHECK-NEXT: <array>
414// CHECK-NEXT: <dict>
415// CHECK-NEXT: <key>start</key>
416// CHECK-NEXT: <array>
417// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000418// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000419// CHECK-NEXT: <key>col</key><integer>2</integer>
420// CHECK-NEXT: <key>file</key><integer>0</integer>
421// CHECK-NEXT: </dict>
422// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000423// CHECK-NEXT: <key>line</key><integer>24</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000424// CHECK-NEXT: <key>col</key><integer>4</integer>
425// CHECK-NEXT: <key>file</key><integer>0</integer>
426// CHECK-NEXT: </dict>
427// CHECK-NEXT: </array>
428// CHECK-NEXT: <key>end</key>
429// CHECK-NEXT: <array>
430// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000431// CHECK-NEXT: <key>line</key><integer>26</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000432// CHECK-NEXT: <key>col</key><integer>2</integer>
433// CHECK-NEXT: <key>file</key><integer>0</integer>
434// CHECK-NEXT: </dict>
435// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000436// CHECK-NEXT: <key>line</key><integer>26</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000437// CHECK-NEXT: <key>col</key><integer>7</integer>
438// CHECK-NEXT: <key>file</key><integer>0</integer>
439// CHECK-NEXT: </dict>
440// CHECK-NEXT: </array>
441// CHECK-NEXT: </dict>
442// CHECK-NEXT: </array>
443// CHECK-NEXT: </dict>
444// CHECK-NEXT: <dict>
445// CHECK-NEXT: <key>kind</key><string>event</string>
446// CHECK-NEXT: <key>location</key>
447// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000448// CHECK-NEXT: <key>line</key><integer>26</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000449// CHECK-NEXT: <key>col</key><integer>2</integer>
450// CHECK-NEXT: <key>file</key><integer>0</integer>
451// CHECK-NEXT: </dict>
452// CHECK-NEXT: <key>ranges</key>
453// CHECK-NEXT: <array>
454// CHECK-NEXT: <array>
455// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000456// CHECK-NEXT: <key>line</key><integer>26</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000457// CHECK-NEXT: <key>col</key><integer>2</integer>
458// CHECK-NEXT: <key>file</key><integer>0</integer>
459// CHECK-NEXT: </dict>
460// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000461// CHECK-NEXT: <key>line</key><integer>26</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000462// CHECK-NEXT: <key>col</key><integer>11</integer>
463// CHECK-NEXT: <key>file</key><integer>0</integer>
464// CHECK-NEXT: </dict>
465// CHECK-NEXT: </array>
466// CHECK-NEXT: </array>
467// CHECK-NEXT: <key>depth</key><integer>0</integer>
468// CHECK-NEXT: <key>extended_message</key>
469// CHECK-NEXT: <string>Attempt to free released memory</string>
470// CHECK-NEXT: <key>message</key>
471// CHECK-NEXT: <string>Attempt to free released memory</string>
472// CHECK-NEXT: </dict>
Anton Yartsev13df0362013-03-25 01:35:45 +0000473// CHECK-NEXT: </array>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000474// CHECK-NEXT: <key>description</key><string>Attempt to free released memory</string>
475// CHECK-NEXT: <key>category</key><string>Memory Error</string>
476// CHECK-NEXT: <key>type</key><string>Double free</string>
477// CHECK-NEXT: <key>issue_context_kind</key><string>function</string>
478// CHECK-NEXT: <key>issue_context</key><string>test</string>
479// CHECK-NEXT: <key>issue_hash</key><string>3</string>
480// CHECK-NEXT: <key>location</key>
481// CHECK-NEXT: <dict>
Pavel Labathfce1b032013-08-28 08:04:08 +0000482// CHECK-NEXT: <key>line</key><integer>26</integer>
Anna Zakse4cfcd42013-04-16 00:22:55 +0000483// CHECK-NEXT: <key>col</key><integer>2</integer>
484// CHECK-NEXT: <key>file</key><integer>0</integer>
485// CHECK-NEXT: </dict>
Anton Yartsev13df0362013-03-25 01:35:45 +0000486// CHECK-NEXT: </dict>
487// CHECK-NEXT: </array>