2007-03-22 10:30:00 -07:00
|
|
|
#!/usr/bin/perl -w
|
|
|
|
#
|
2012-05-21 04:12:37 -07:00
|
|
|
# This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
# License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
2007-03-22 10:30:00 -07:00
|
|
|
|
2008-08-04 19:05:50 -07:00
|
|
|
use strict;
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
my %allocs;
|
2008-08-04 19:05:50 -07:00
|
|
|
my %classes;
|
2007-03-22 10:30:00 -07:00
|
|
|
my %counter;
|
|
|
|
|
|
|
|
LINE: while (<>) {
|
|
|
|
next LINE if (! /^</);
|
|
|
|
|
2008-08-04 19:05:50 -07:00
|
|
|
my @fields = split(/ /, $_);
|
2007-03-22 10:30:00 -07:00
|
|
|
my $class = shift(@fields);
|
|
|
|
my $obj = shift(@fields);
|
|
|
|
my $sno = shift(@fields);
|
|
|
|
my $op = shift(@fields);
|
|
|
|
my $cnt = shift(@fields);
|
|
|
|
|
2010-01-07 12:14:27 -08:00
|
|
|
# for AddRef/Release $cnt is the refcount, for Ctor/Dtor it's the size
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
if ($op eq 'AddRef' && $cnt == 1) {
|
2008-08-04 19:05:50 -07:00
|
|
|
# Example: <nsStringBuffer> 0x01AFD3B8 1 AddRef 1
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
$allocs{$obj} = ++$counter{$class}; # the order of allocation
|
|
|
|
$classes{$obj} = $class;
|
|
|
|
}
|
|
|
|
elsif ($op eq 'Release' && $cnt == 0) {
|
2008-08-04 19:05:50 -07:00
|
|
|
# Example: <nsStringBuffer> 0x01AFD3B8 1 Release 0
|
|
|
|
|
2007-03-22 10:30:00 -07:00
|
|
|
delete($allocs{$obj});
|
2008-08-04 19:05:50 -07:00
|
|
|
delete($classes{$obj});
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
2010-01-07 12:14:27 -08:00
|
|
|
elsif ($op eq 'Ctor') {
|
2010-02-20 05:58:06 -08:00
|
|
|
# Example: <PStreamNotifyParent> 0x08880BD0 8 Ctor (20)
|
2010-01-07 12:14:27 -08:00
|
|
|
|
2010-02-20 05:58:06 -08:00
|
|
|
$allocs{$obj} = ++$counter{$class};
|
|
|
|
$classes{$obj} = $class;
|
2010-01-07 12:14:27 -08:00
|
|
|
}
|
|
|
|
elsif ($op eq 'Dtor') {
|
2010-02-20 05:58:06 -08:00
|
|
|
# Example: <PStreamNotifyParent> 0x08880BD0 8 Dtor (20)
|
2010-01-07 12:14:27 -08:00
|
|
|
|
2010-02-20 05:58:06 -08:00
|
|
|
delete($allocs{$obj});
|
|
|
|
delete($classes{$obj});
|
2010-01-07 12:14:27 -08:00
|
|
|
}
|
2007-03-22 10:30:00 -07:00
|
|
|
}
|
|
|
|
|
2008-08-04 19:05:50 -07:00
|
|
|
|
|
|
|
sub sort_by_value {
|
|
|
|
my %x = @_;
|
|
|
|
sub _by_value($) { my %x = @_; $x{$a} cmp $x{$b}; }
|
|
|
|
sort _by_value keys(%x);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
foreach my $key (&sort_by_value(%allocs)) {
|
|
|
|
# Example: 0x03F1D818 (2078) @ <nsStringBuffer>
|
2007-03-22 10:30:00 -07:00
|
|
|
print "$key (", $allocs{$key}, ") @ ", $classes{$key}, "\n";
|
|
|
|
}
|