Initial Commit
This commit is contained in:
111
database/perl/vendor/lib/Mojolicious/Command/version.pm
vendored
Normal file
111
database/perl/vendor/lib/Mojolicious/Command/version.pm
vendored
Normal file
@@ -0,0 +1,111 @@
|
||||
package Mojolicious::Command::version;
|
||||
use Mojo::Base 'Mojolicious::Command';
|
||||
|
||||
use Mojo::IOLoop::Client;
|
||||
use Mojo::IOLoop::TLS;
|
||||
use Mojo::JSON;
|
||||
use Mojolicious;
|
||||
|
||||
has description => 'Show versions of available modules';
|
||||
has usage => sub { shift->extract_usage };
|
||||
|
||||
sub run {
|
||||
my $self = shift;
|
||||
|
||||
my $json = Mojo::JSON->JSON_XS ? $Cpanel::JSON::XS::VERSION : 'n/a';
|
||||
my $ev = eval { require Mojo::Reactor::EV; 1 } ? $EV::VERSION : 'n/a';
|
||||
my $socks = Mojo::IOLoop::Client->can_socks ? $IO::Socket::Socks::VERSION : 'n/a';
|
||||
my $tls = Mojo::IOLoop::TLS->can_tls ? $IO::Socket::SSL::VERSION : 'n/a';
|
||||
my $nnr = Mojo::IOLoop::Client->can_nnr ? $Net::DNS::Native::VERSION : 'n/a';
|
||||
my $roles = Mojo::Base->ROLES ? $Role::Tiny::VERSION : 'n/a';
|
||||
my $async = Mojo::Base->ASYNC ? $Future::AsyncAwait::VERSION : 'n/a';
|
||||
|
||||
print <<EOF;
|
||||
CORE
|
||||
Perl ($^V, $^O)
|
||||
Mojolicious ($Mojolicious::VERSION, $Mojolicious::CODENAME)
|
||||
|
||||
OPTIONAL
|
||||
Cpanel::JSON::XS 4.09+ ($json)
|
||||
EV 4.32+ ($ev)
|
||||
IO::Socket::Socks 0.64+ ($socks)
|
||||
IO::Socket::SSL 2.009+ ($tls)
|
||||
Net::DNS::Native 0.15+ ($nnr)
|
||||
Role::Tiny 2.000001+ ($roles)
|
||||
Future::AsyncAwait 0.36+ ($async)
|
||||
|
||||
EOF
|
||||
|
||||
# Check latest version on CPAN
|
||||
my $latest = eval {
|
||||
$self->app->ua->max_redirects(10)->tap(sub { $_->proxy->detect })
|
||||
->get('fastapi.metacpan.org/v1/release/Mojolicious')->result->json->{version};
|
||||
} or return;
|
||||
|
||||
my $msg = 'This version is up to date, have fun!';
|
||||
$msg = 'Thanks for testing a development release, you are awesome!' if $latest < $Mojolicious::VERSION;
|
||||
$msg = "You might want to update your Mojolicious to $latest!" if $latest > $Mojolicious::VERSION;
|
||||
say $msg;
|
||||
}
|
||||
|
||||
1;
|
||||
|
||||
=encoding utf8
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Mojolicious::Command::version - Version command
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
Usage: APPLICATION version [OPTIONS]
|
||||
|
||||
mojo version
|
||||
|
||||
Options:
|
||||
-h, --help Show this summary of available options
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
L<Mojolicious::Command::version> shows version information for available core and optional modules.
|
||||
|
||||
This is a core command, that means it is always enabled and its code a good example for learning to build new commands,
|
||||
you're welcome to fork it.
|
||||
|
||||
See L<Mojolicious::Commands/"COMMANDS"> for a list of commands that are available by default.
|
||||
|
||||
=head1 ATTRIBUTES
|
||||
|
||||
L<Mojolicious::Command::version> inherits all attributes from L<Mojolicious::Command> and implements the following new
|
||||
ones.
|
||||
|
||||
=head2 description
|
||||
|
||||
my $description = $v->description;
|
||||
$v = $v->description('Foo');
|
||||
|
||||
Short description of this command, used for the command list.
|
||||
|
||||
=head2 usage
|
||||
|
||||
my $usage = $v->usage;
|
||||
$v = $v->usage('Foo');
|
||||
|
||||
Usage information for this command, used for the help screen.
|
||||
|
||||
=head1 METHODS
|
||||
|
||||
L<Mojolicious::Command::version> inherits all methods from L<Mojolicious::Command> and implements the following new
|
||||
ones.
|
||||
|
||||
=head2 run
|
||||
|
||||
$v->run(@ARGV);
|
||||
|
||||
Run this command.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<Mojolicious>, L<Mojolicious::Guides>, L<https://mojolicious.org>.
|
||||
|
||||
=cut
|
||||
Reference in New Issue
Block a user