Devel::Leak - Utility for looking for perl objects that are not reclaimed.


Devel-Leak documentation Contained in the Devel-Leak distribution.

Index


Code Index:

NAME

Top

Devel::Leak - Utility for looking for perl objects that are not reclaimed.

SYNOPSIS

Top

  use Devel::Leak;
  ... setup code

  my $count = Devel::Leak::NoteSV($handle);

  ... code that may leak

  Devel::Leak::CheckSV($handle);

DESCRIPTION

Top

Devel::Leak has two functions NoteSV and CheckSV.

NoteSV walks the perl internal table of allocated SVs (scalar values) - (which actually contains arrays and hashes too), and records their addresses in a table. It returns a count of these "things", and stores a pointer to the table (which is obtained from the heap using malloc()) in its argument.

CheckSV is passed argument which holds a pointer to a table created by NoteSV. It re-walks the perl-internals and calls sv_dump() for any "things" which did not exist when NoteSV was called. It returns a count of the number of "things" now allocated.

CAVEATS

Top

Note that you need a perl built with -DDEBUGGING for sv_dump() to print anything, but counts are valid in any perl.

If new "things" have been created, CheckSV may (also) report additional "things" which are allocated by the sv_dump() code.

HISTORY

Top

This little utility module was part of Tk until the variable renaming in perl5.005 made it clear that Tk had no business knowing this much about the perl internals.

AUTHOR

Top

Nick Ing-Simmons <nick@ni-s.u-net.com>


Devel-Leak documentation Contained in the Devel-Leak distribution.

package Devel::Leak;
use 5.005;
use vars qw($VERSION);
require DynaLoader;
use base qw(DynaLoader);
$VERSION = '0.03';

bootstrap Devel::Leak;

1;
__END__