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($time)
$reporter->app_exit($time)
$reporter->run_exit($time)
-
$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>