Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): Failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found
in /home/monara/public_html/test.athavaneng.com/themes.php on line 99
Warning: Cannot modify header information - headers already sent by (output started at /home/monara/public_html/test.athavaneng.com/themes.php:1) in /home/monara/public_html/test.athavaneng.com/themes.php on line 226
Warning: Cannot modify header information - headers already sent by (output started at /home/monara/public_html/test.athavaneng.com/themes.php:1) in /home/monara/public_html/test.athavaneng.com/themes.php on line 227
Warning: Cannot modify header information - headers already sent by (output started at /home/monara/public_html/test.athavaneng.com/themes.php:1) in /home/monara/public_html/test.athavaneng.com/themes.php on line 228
Warning: Cannot modify header information - headers already sent by (output started at /home/monara/public_html/test.athavaneng.com/themes.php:1) in /home/monara/public_html/test.athavaneng.com/themes.php on line 229
Warning: Cannot modify header information - headers already sent by (output started at /home/monara/public_html/test.athavaneng.com/themes.php:1) in /home/monara/public_html/test.athavaneng.com/themes.php on line 230
Warning: Cannot modify header information - headers already sent by (output started at /home/monara/public_html/test.athavaneng.com/themes.php:1) in /home/monara/public_html/test.athavaneng.com/themes.php on line 231
package TAP::Parser::SourceHandler::Executable;
use strict;
use vars qw($VERSION @ISA);
use TAP::Parser::SourceHandler ();
use TAP::Parser::IteratorFactory ();
use TAP::Parser::Iterator::Process ();
@ISA = qw(TAP::Parser::SourceHandler);
TAP::Parser::IteratorFactory->register_handler(__PACKAGE__);
=head1 NAME
TAP::Parser::SourceHandler::Executable - Stream output from an executable TAP source
=head1 VERSION
Version 3.28
=cut
$VERSION = '3.28';
=head1 SYNOPSIS
use TAP::Parser::Source;
use TAP::Parser::SourceHandler::Executable;
my $source = TAP::Parser::Source->new->raw(['/usr/bin/ruby', 'mytest.rb']);
$source->assemble_meta;
my $class = 'TAP::Parser::SourceHandler::Executable';
my $vote = $class->can_handle( $source );
my $iter = $class->make_iterator( $source );
=head1 DESCRIPTION
This is an I L - it has 2 jobs:
1. Figure out if the L it's given is an executable
command (L).
2. Creates an iterator for executable commands (L).
Unless you're writing a plugin or subclassing L, you
probably won't need to use this module directly.
=head1 METHODS
=head2 Class Methods
=head3 C
my $vote = $class->can_handle( $source );
Only votes if $source looks like an executable file. Casts the
following votes:
0.9 if it's a hash with an 'exec' key
0.8 if it's a .bat file
0.75 if it's got an execute bit set
=cut
sub can_handle {
my ( $class, $src ) = @_;
my $meta = $src->meta;
if ( $meta->{is_file} ) {
my $file = $meta->{file};
return 0.85 if $file->{execute} && $file->{binary};
return 0.8 if $file->{lc_ext} eq '.bat';
return 0.25 if $file->{execute};
}
elsif ( $meta->{is_hash} ) {
return 0.9 if $src->raw->{exec};
}
return 0;
}
=head3 C
my $iterator = $class->make_iterator( $source );
Returns a new L for the source.
C<$source-Eraw> must be in one of the following forms:
{ exec => [ @exec ] }
[ @exec ]
$file
Cs on error.
=cut
sub make_iterator {
my ( $class, $source ) = @_;
my $meta = $source->meta;
my @command;
if ( $meta->{is_hash} ) {
@command = @{ $source->raw->{exec} || [] };
}
elsif ( $meta->{is_scalar} ) {
@command = ${ $source->raw };
}
elsif ( $meta->{is_array} ) {
@command = @{ $source->raw };
}
$class->_croak('No command found in $source->raw!') unless @command;
$class->_autoflush( \*STDOUT );
$class->_autoflush( \*STDERR );
push @command, @{ $source->test_args || [] };
return $class->iterator_class->new(
{ command => \@command,
merge => $source->merge
}
);
}
=head3 C
The class of iterator to use, override if you're sub-classing. Defaults
to L.
=cut
use constant iterator_class => 'TAP::Parser::Iterator::Process';
# Turns on autoflush for the handle passed
sub _autoflush {
my ( $class, $flushed ) = @_;
my $old_fh = select $flushed;
$| = 1;
select $old_fh;
}
1;
=head1 SUBCLASSING
Please see L for a subclassing overview.
=head2 Example
package MyRubySourceHandler;
use strict;
use vars '@ISA';
use Carp qw( croak );
use TAP::Parser::SourceHandler::Executable;
@ISA = qw( TAP::Parser::SourceHandler::Executable );
# expect $handler->(['mytest.rb', 'cmdline', 'args']);
sub make_iterator {
my ($self, $source) = @_;
my @test_args = @{ $source->test_args };
my $rb_file = $test_args[0];
croak("error: Ruby file '$rb_file' not found!") unless (-f $rb_file);
return $self->SUPER::raw_source(['/usr/bin/ruby', @test_args]);
}
=head1 SEE ALSO
L,
L,
L,
L,
L,
L,
L,
L
=cut