Bug 435739 Poor performance of Firefox 3 with no X RENDER extension
[wine-gecko.git] / tools / leaky / TestLeaky.cpp
blob37200043c48d6dcd632b1ada86cab2ab5ef4079c
1 /* ***** BEGIN LICENSE BLOCK *****
2 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4 * The contents of this file are subject to the Mozilla Public License Version
5 * 1.1 (the "License"); you may not use this file except in compliance with
6 * the License. You may obtain a copy of the License at
7 * http://www.mozilla.org/MPL/
9 * Software distributed under the License is distributed on an "AS IS" basis,
10 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
11 * for the specific language governing rights and limitations under the
12 * License.
14 * The Original Code is mozilla.org code.
16 * The Initial Developer of the Original Code is
17 * Kipp E.B. Hickman.
18 * Portions created by the Initial Developer are Copyright (C) 1999
19 * the Initial Developer. All Rights Reserved.
21 * Contributor(s):
23 * Alternatively, the contents of this file may be used under the terms of
24 * either the GNU General Public License Version 2 or later (the "GPL"), or
25 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
26 * in which case the provisions of the GPL or the LGPL are applicable instead
27 * of those above. If you wish to allow use of your version of this file only
28 * under the terms of either the GPL or the LGPL, and not to allow others to
29 * use your version of this file under the terms of the MPL, indicate your
30 * decision by deleting the provisions above and replace them with the notice
31 * and other provisions required by the GPL or the LGPL. If you do not delete
32 * the provisions above, a recipient may use your version of this file under
33 * the terms of any one of the MPL, the GPL or the LGPL.
35 * ***** END LICENSE BLOCK ***** */
37 #include <stdio.h>
38 #include <malloc.h>
40 void s1(int, int)
42 malloc(100);
45 void s2()
47 s1(1, 2);
48 malloc(100);
51 void s3()
53 s2();
54 malloc(100);
55 malloc(200);
58 void s4()
60 s3();
61 char* cp = new char[300];
62 cp = cp;
65 // Test that mutually recrusive methods don't foul up the graph output
66 void s6(int recurse);
68 void s5(int recurse)
70 malloc(100);
71 if (recurse > 0) {
72 s6(recurse - 1);
76 void s6(int recurse)
78 malloc(100);
79 if (recurse > 0) {
80 s5(recurse - 1);
84 // Test that two pathways through the same node don't cause replicated
85 // descdendants (A -> B -> C, X -> B -> D shouldn't produce a graph
86 // that shows A -> B -> D!)
88 void C()
90 malloc(10);
93 void D()
95 malloc(10);
98 void B(int way)
100 malloc(10);
101 if (way) {
102 C();
103 C();
104 C();
105 } else {
106 D();
110 void A()
112 malloc(10);
113 B(1);
116 void X()
118 malloc(10);
119 B(0);
122 int main()
124 s1(1, 2);
125 s2();
126 s3();
127 s4();
128 s5(10);
129 A();
130 X();