#!/usr/bin/perl -w # Description: Fool a process into # thinking that STDOUT is a terminal, when in fact # it may be a file or a pipe. This can be useful # with programs like ps and w on linux... which # will trunc their output to the width of the # terminal, and, if they cannot detect the terminal # width, use a default 80 columns. Wouldn't it be # nice to say "ps -aux | grep etcshadow", and get # output that looks like when you just say "ps # -aux"? Well, that's the idea. #try ./pseudotty "xterm -e top" #or ./pseudotty top use warnings; use strict; use IO::Pty; die "usage: ptyexec command [args]\n" unless @ARGV; my $pty = IO::Pty->new; my $slave = $pty->slave; open TTY,"/dev/tty" or die "not connected to a terminal\n"; $pty->clone_winsize_from(\*TTY); close TTY; my $pid = fork(); die "bad fork: $!\n" unless defined $pid; if (!$pid) { # $slave->close(); open STDOUT,">&=".$pty->fileno() or die $!; exec @ARGV; }else{ $pty->close(); while (defined (my $line = <$slave>)) { print $line; } } #cleanup pty for next run $pty->close(); #### #!/usr/bin/perl use IO::Handle; use IO::Pty; sub do_cmd() { my $pty = new IO::Pty; defined( my $child = fork ) or die "Can't fork: $!"; if ($child){ $pty->close_slave(); #needed to close return $pty; } POSIX::setsid(); my $slave = $pty->slave; close($pty); STDOUT->fdopen( $slave, '>' ) || die $!; STDERR->fdopen( \*STDOUT, '>' ) || die $!; system("echo This is stdout output from an external program"); exit 0; } my $fh = do_cmd(); while (<$fh>) { print; } #### #!/usr/bin/perl use warnings; use strict; use IPC::Open3; $|=1; #my $pid=open3(\*IN,\*OUT,\*ERR,'/bin/bash'); my $pid=open3(\*IN,\*OUT,0,'/bin/bash'); # set \*ERR to 0 to send STDERR to STDOUT my $cmd = 'date'; #my $cmd = 'ps auxww'; #my $cmd = 'top'; #send cmd to bash print IN "$cmd\n"; # won't work with 'top' or 'ps' #print IN "l"; #print IN "m"; #print IN "t"; #print IN "\n"; #getresult my $result = ; print $result;