K2LL33D SHELL

 Apache/2.4.7 (Ubuntu)
 Linux sman1baleendah 3.13.0-24-generic #46-Ubuntu SMP Thu Apr 10 19:11:08 UTC 2014 x86_64
 uid=33(www-data) gid=33(www-data) groups=33(www-data)
 safemode : OFF
 MySQL: ON | Perl: ON | cURL: OFF | WGet: ON
  >  / usr / share / perl / 5.18.2 / CPANPLUS / Dist /
server ip : 172.67.156.115

your ip : 172.69.7.22

H O M E


Filename/usr/share/perl/5.18.2/CPANPLUS/Dist/Autobundle.pm
Size3.56 kb
Permissionrw-r--r--
Ownerroot : root
Create time27-Apr-2025 10:10
Last modified21-Nov-2018 01:11
Last accessed08-Jul-2025 00:31
Actionsedit | rename | delete | download (gzip)
Viewtext | code | image
package CPANPLUS::Dist::Autobundle;
use deprecate;

use strict;
use warnings;
use CPANPLUS::Error qw[error msg];
use Params::Check qw[check];
use Locale::Maketext::Simple Class => 'CPANPLUS', Style => 'gettext';
use vars qw[$VERSION];
$VERSION = "0.9135";

use base qw[CPANPLUS::Dist::Base];

=head1 NAME

CPANPLUS::Dist::Autobundle - distribution class for installation snapshots

=head1 SYNOPSIS

$modobj = $cb->parse_module( module => 'file://path/to/Snapshot_XXYY.pm' );
$modobj->install;

=head1 DESCRIPTION

C<CPANPLUS::Dist::Autobundle> is a distribution class for installing installation
snapshots as created by C<CPANPLUS>' C<autobundle> command.

All modules as mentioned in the snapshot will be installed on your system.

=cut

sub init {
my $dist = shift;
my $status = $dist->status;

$status->mk_accessors(
qw[prepared created installed _prepare_args _create_args _install_args]
);

return 1;
}

sub prepare {
my $dist = shift;
my %args = @_;

### store the arguments, so ->install can use them in recursive loops ###
$dist->status->_prepare_args( \%args );

return $dist->status->prepared( 1 );
}

sub create {
my $dist = shift;
my $self = $dist->parent;

### we're also the cpan_dist, since we don't need to have anything
### prepared
$dist = $self->status->dist_cpan if $self->status->dist_cpan;
$self->status->dist_cpan( $dist ) unless $self->status->dist_cpan;

my $cb = $self->parent;
my $conf = $cb->configure_object;
my %hash = @_;

my( $force, $verbose, $prereq_target, $prereq_format, $prereq_build);

my $args = do {
local $Params::Check::ALLOW_UNKNOWN = 1;
my $tmpl = {
force => { default => $conf->get_conf('force'),
store => \$force },
verbose => { default => $conf->get_conf('verbose'),
store => \$verbose },
prereq_target => { default => '', store => \$prereq_target },

### don't set the default prereq format to 'makemaker' -- wrong!
prereq_format => { #default => $self->status->installer_type,
default => '',
store => \$prereq_format },
prereq_build => { default => 0, store => \$prereq_build },
};

check( $tmpl, \%hash ) or return;
};

### maybe we already ran a create on this object? ###
return 1 if $dist->status->created && !$force;

### store the arguments, so ->install can use them in recursive loops ###
$dist->status->_create_args( \%hash );

msg(loc("Resolving prerequisites mentioned in the bundle"), $verbose);

### this will set the directory back to the start
### dir, so we must chdir /again/
my $ok = $dist->_resolve_prereqs(
format => $prereq_format,
verbose => $verbose,
prereqs => $self->status->prereqs,
target => $prereq_target,
force => $force,
prereq_build => $prereq_build,
);

### if all went well, mark it & return
return $dist->status->created( $ok ? 1 : 0);
}

sub install {
my $dist = shift;
my %args = @_;

### store the arguments, so ->install can use them in recursive loops ###
$dist->status->_install_args( \%args );

return $dist->status->installed( 1 );
}

1;