App-Cleo-Patra
view release on metacpan or search on metacpan
lib/App/Cleo/Patra.pm view on Meta::CPAN
$continue_to_end = 1 if $key eq 'c';
$self->do_cmd($cmd);
}
ReadMode('restore');
print "\n";
return $self;
}
#-----------------------------------------------------------------------------
sub do_cmd {
my ($self, $cmd) = @_;
my $cmd_is_finished;
local $SIG{ALRM} = sub {$cmd_is_finished = 1};
$cmd =~ s/%%%//g;
my $fh = $self->{fh};
print $fh "$cmd\n";
($self->{state} = PS2) and return 1
if $cmd =~ m{\s+\\$};
print $fh "kill -14 $$\n";
$fh->flush;
# Wait for signal that command has ended
until ($cmd_is_finished) {}
$cmd_is_finished = 0;
$self->{state} = PS1;
return 1;
}
#-----------------------------------------------------------------------------
1;
=pod
=encoding utf8
=head1 NAME
App::Cleo - Play back shell commands for live demonstrations
=head1 SYNOPSIS
use App::Cleo::Patra
my $patra = App::Cleo::Patra->new(%options);
$patra->run($commands);
=head1 DESCRIPTION
B<Important:>
C<patra> is an experimental fork from C<cleo>.
You should check the current differences from C<App-Cleo> and decide, which one you want to use.
It may be, that in your current time, C<patra> is merged back into C<cleo> or obsolete for other reasons.
App::Cleo::Patra is the back-end for the L<patra> utility. Please see the L<patra>
documentation for details on how to use this.
=head1 CONSTRUCTOR
The constructor accepts arguments as key-value pairs. The following keys are
supported:
=over 4
=item delay
Number of microseconds to wait before displaying each character of the command.
The default is C<25_000>.
=item ps1
String to use for the artificial prompt. The token C<%d> will be substituted
with the number of the current command. The default is C<(%d)$>.
=item ps2
String to use for the artificial prompt that appears for multiline commands. The
token C<%d> will be substituted with the number of the current command. The
default is C<< > >>.
=item shell
Path to the shell command that will be used to run the commands. Defaults to
either the C<SHELL> environment variable or C</bin/bash>.
=back
=head1 METHODS
=over 4
=item run( $commands )
Starts playback of commands. If the argument is a string, it will be treated
as a file name and commands will be read from the file. If the argument is a
scalar reference, it will be treated as a string of commands separated by
newlines. If the argument is an array reference, then each element of the
array will be treated as a command.
=back
=head1 AUTHOR
Jeffrey Ryan Thalhammer <thaljef@cpan.org>
Boris Däppeb (BORISD) <bdaeppen.perl@gmail.com>
=head1 COPYRIGHT
cleo - Copyright (c) 2014, Imaginative Software Systems
patra - Boris Däppen (BORISD) 2018
( run in 2.160 seconds using v1.01-cache-2.11-cpan-75ffa21a3d4 )