NAME
IO::CaptureOutput - capture STDOUT and STDERR from Perl code, subprocesses or XS
VERSION
This documentation describes version 1.04_01.
SYNOPSIS
use IO::CaptureOutput qw(capture capture_exec qxx);
my ($stdout, $stderr);
capture sub {noisy(@args)}, \$stdout, \$stderr;
sub noisy {
my @args = @_;
warn "this sub prints to stdout and stderr!";
...
print "finished";
}
($stdout, $stderr) = capture_exec( 'perl', '-e',
'print "Hello "; print STDERR "World!"');
DESCRIPTION
This module provides routines for capturing STDOUT and STDERR from forked system calls (e.g. system()
, fork()
) and from XS/C modules.
FUNCTIONS
The following functions are be exported on demand.
capture(\&subroutine, \$output, \$error)
Captures everything printed to STDOUT
and STDERR
for the duration of &subroutine
. $output
and $error
are optional scalar references that will contain STDOUT
and STDERR
respectively.
Returns the return value(s) of &subroutine
. The sub is called in the same context as capture()
was called e.g.:
@rv = capture(sub {wantarray}); # returns true
$rv = capture(sub {wantarray}); # returns defined, but not true
capture(sub {wantarray}); # void, returns undef
capture()
is able to trap output from subprocesses and C code, which traditional tie()
methods are unable to capture.
Note: capture()
will only capture output that has been written or flushed to the filehandle.
capture_exec(@args)
Captures and returns the output from system(@args)
. In scalar context, capture_exec()
will return what was printed to STDOUT
. In list context, it returns what was printed to STDOUT
and STDERR
my $output = capture_exec('perl', '-e', 'print "hello world"');
my ($output, $error) = capture_exec('perl', '-e', 'warn "Test"');
capture_exec
passes its arguments to CORE::system
it can take advantage of the shell quoting, which makes it a handy and slightly more portable alternative to backticks, piped open()
and IPC::Open3
.
You can check the exit status of the system()
call with the $?
variable. See perlvar for more information.
qxx(@args)
This is an alias of capture_exec
SEE ALSO
AUTHORS
Simon Flack <simonflk _AT_ cpan.org> (original author)
David Golden <dagolden _AT_ cpan.org> (co-maintainer since version 1.04)
COPYRIGHT AND LICENSE
Portions copyright 2004, 2005 Simon Flack. Portions copyright 2007 David Golden. All rights reserved.
You may distribute under the terms of either the GNU General Public License or the Artistic License, as specified in the Perl README file.