in reply to Re (tilly) 1: Redirecting STDOUT to a variable via eval?
in thread Redirecting STDOUT to a variable via eval?

That is because tie only is working on Perl IO. A system command hands the file descriptor for STDOUT to the command being launched, which knows nothing about Perl's IO.

The same gotcha exists for working with C extensions that do their own printing.

For one solution you can do a piped open like this:

use IPC::Open3; sub piped_cmd { local *TO; local *FROM; open3 (\*TO, \*FROM, \*FROM, "perl") or die "Cannot launch perl: $!" +; print TO @_, "\n__END__\n"; local $/; <FROM>; }
(That is portable, Windows and Unix.)

Note that doing things that way does not give access to various things that you have defined in your script. If you want that you are probably out of luck because all of the methods that I know of for IO games (select, tie, etc) work at the Perl level, and leave the C file-descriptors alone. But then when you call system the program works by file descriptor. :-(

This could be construed as a bug.