Provided by: libipc-run3-perl_0.048-3_all bug

NAME

       IPC::Run3::ProfReporter - base class for handling profiling data

SYNOPSIS

DESCRIPTION

       See IPC::Run3::ProfPP and for an example subclass.

       This class just notes and accumulates times; subclasses use methods like
       "handle_app_call", "handle_run_exit" and "handle_app_exit" to emit reports on it.  The
       default methods for these handlers are noops.

       If run from the command line, a reporter will be created and run on each logfile given as
       a command line parameter or on run3.out if none are given.

       This allows reports to be run like:

           perl -MIPC::Run3::ProfPP -e1
           perl -MIPC::Run3::ProfPP -e1 foo.out bar.out

       Use "-" to read from STDIN (the log file format is meant to be moderately greppable):

           grep "^cvs " run3.out perl -MIPC::Run3::ProfPP -e1 -

       Use --app to show only application level statistics (ie don't emit a report section for
       each command run).

METHODS

       "IPC::Run3::ProfReporter->new"
           Returns a new profile reporting object.

       "$reporter->handle_app_call( ... )"
       "$reporter->handle_app_exit( ... )"
       "$reporter->handle_run_exit( ... )"
           These methods are called by the handled events (see below).

       "$reporter->app_call(\@cmd, $time)"
       "$reporter->app_exit($time)"
       "$reporter->run_exit(@times)"
              $self->app_call( $time );
              my $time = $self->get_app_call_time;

           Sets the time (in floating point seconds) when the application, run3(), or system()
           was called or exited.  If no time parameter is passed, uses IPC::Run3's time routine.

           Use get_...() to retrieve these values (and _accum values, too).  This is a separate
           method to speed the execution time of the setters just a bit.

       "$reporter->get_run_count()"
       "$reporter->get_app_call_time()"
       "$reporter->get_app_exit_time()"
       "$reporter->get_app_cmd()"
       "$reporter->get_app_time()"
       "$reporter->get_app_cumulative_time()"
       "$reporter->get_run_call_time()"
       "$reporter->get_run_exit_time()"
       "$reporter->get_run_time()"
       "$reporter->get_run_cumulative_time()"
       "$reporter->get_sys_call_time()"
       "$reporter->get_sys_exit_time()"
       "$reporter->get_sys_time()"
       "$reporter->get_sys_cumulative_time()"
       "$reporter->get_run_cmd()"

LIMITATIONS

COPYRIGHT

           Copyright 2003, R. Barrie Slaymaker, Jr., All Rights Reserved

LICENSE

       You may use this module under the terms of the BSD, Artistic, or GPL licenses, any
       version.

AUTHOR

       Barrie Slaymaker <barries@slaysys.com>