Provided by: libdevel-mat-dumper-perl_0.45-1_amd64 bug

NAME

       "Devel::MAT::Dumper" - write a heap dump file for later analysis

SYNOPSIS

        use Devel::MAT::Dumper;

        Devel::MAT::Dumper::dump( "path/to/the/file.pmat" );

DESCRIPTION

       This module provides the memory-dumping function that creates a heap dump file which can
       later be read by Devel::MAT::Dumpfile. It provides a single function which is not
       exported, which writes a file to the given path.

       The dump file will contain a representation of every SV in Perl's arena, providing
       information about pointers between them, as well as other information about the state of
       the process at the time it was created. It contains a snapshot of the process at that
       moment in time, which can later be loaded and analysed by various tools using
       "Devel::MAT::Dumpfile".

       This module used to be part of the main Devel::MAT distribution but is now in its own one
       so that it can be installed independently on servers or other locations where perl
       processes need to inspected but analysis tools can be run elsewhere.

IMPORT OPTIONS

       The following "import" options control the behaviour of the module. They may primarily be
       useful when used in the "-M" perl option:

   -dump_at_DIE
       Installs a handler for the special "__DIE__" signal to write a dump file when "die()" is
       about to cause a fatal signal. This is more reliable at catching the callstack and memory
       state than using an "END" block.

          $ perl -MDevel::MAT::Dumper=-dump_at_DIE ...

   -dump_at_WARN
       Installs a handler for the special "__WARN__" signal to write a dump file when perl prints
       a warning.

          $ perl -MDevel::MAT::Dumper=-dump_at_WARN ...

       It is likely useful to combine this with the "NNN" numbering feature of the "-file"
       argument, to ensure that later warnings don't overwrite a particular file.

   -dump_at_END
       Installs an "END" block which writes a dump file at "END" time, just before the
       interpreter exits.

          $ perl -MDevel::MAT::Dumper=-dump_at_END ...

   -dump_at_SIGQUIT
       Installs a handler for "SIGQUIT" to write a dump file if the signal is received. The
       signal handler will remain in place and can be used several times.

          $ perl -MDevel::MAT::Dumper=-dump_at_SIGQUIT ...

       Take care if you are using the "<Ctrl-\>" key combination on a terminal to send this
       signal to a foreground process, because if it has "fork()"ed any background workers or
       similar, the signal will also be delivered to those as well.

   -dump_at_SIGNAME
       Installs a handler for the named signal (e.g. "SIGABRT", "SIGINT") to write a dump file if
       the signal is received. After dumping the file, the signal handler is removed and the
       signal re-raised.

          $ perl -MDevel::MAT::Dumper=-dump_at_SIGABRT ...

       Note that "SIGABRT" uses an "unsafe" signal handler (i.e. not deferred until the next perl
       op), so it can capture the full context of any ongoing XS or C library operations.

   -file $PATH
       Sets the name of the file which is automatically dumped; defaults to basename $0.pmat if
       not supplied.

          $ perl -MDevel::MAT::Dumper=-file,foo.pmat ...

       In the special case that $0 is exactly the string "-e" or "-E", the filename will be
       prefixed with "perl" so as not to create files whose names begin with a leading hyphen, as
       this confuses some commandline parsers.

          $ perl -MDevel::MAT::Dumper=-dump_at_END -E 'say "hello"'
          hello
          Dumping to perl-e.pmat because of END

       If the pattern contains "NNN", this will be replaced by a unique serial number per written
       file, starting from 0. This may be helpful in the case of "DIE", "WARN" or "SIGQUIT"
       handlers, which could be invoked multiple times.

       The file name is converted to an absolute path immediately, so if the running program
       later calls "chdir()", it will still be generated in the directory the program started
       from rather than the one it happens to be in at the time.

   -max_string
       Sets the maximum length of string buffer to dump from PVs; defaults to 256 if not
       supplied. Use a negative size to dump the entire buffer of every PV regardless of size.

   -eager_open
       Opens the dump file immediately at "import" time, instead of waiting until the time it
       actually writes the heap dump. This may be useful if the process changes user ID, or to
       debug problems involving too many open filehandles.

FUNCTIONS

       These functions are not exported, they must be called fully-qualified.

   dump
          dump( $path )

       Writes a heap dump to the named file

   dumpfh
          dumpfh( $fh )

       Writes a heap dump to the given filehandle (which must be a plain OS-level filehandle,
       though does not need to be a regular file, or seekable).

AUTHOR

       Paul Evans <leonerd@leonerd.org.uk>