Alien-SDL2
view release on metacpan or search on metacpan
inc/My/Builder.pm view on Meta::CPAN
package My::Builder;
use strict;
use warnings;
use base 'Module::Build';
use lib "inc";
use My::Utility qw(find_SDL2_dir find_file sed_inplace get_dlext);
use File::Spec::Functions qw(catdir catfile splitpath catpath rel2abs abs2rel);
use File::Path qw(make_path remove_tree);
use File::Copy qw(cp);
use File::Fetch;
use File::Find;
use File::ShareDir;
use Archive::Extract;
use Digest::SHA qw(sha1_hex);
use Text::Patch;
use Config;
use IPC::Run3;
$SIG{__WARN__} = sub {
my $thing = join('', @_);
$thing =~ s|(://.+:).+(\@.+)|$1******$2|;
warn $thing;
return 1;
};
sub ACTION_build {
my $self = shift;
# as we want to wipe 'sharedir' during 'Build clean' we has
# to recreate 'sharedir' at this point if it does not exist
my $bp = $self->notes('build_params');
die "###ERROR### Cannot continue build_params not defined" unless defined($bp);
printf("Build option used:\n\t%s\n", $bp->{title} || 'n.a.');
mkdir 'sharedir' unless(-d 'sharedir');
$self->add_to_cleanup('sharedir');
$self->SUPER::ACTION_build;
}
sub ACTION_install
{
my $self = shift;
my $sharedir = '';
$sharedir = eval {File::ShareDir::dist_dir('Alien-SDL2')} || '';
if ( -d $sharedir )
{
print "Removing the old $sharedir \n";
remove_tree($sharedir);
make_path($sharedir);
}
$self->SUPER::ACTION_install;
}
sub ACTION_code {
my $self = shift;
my $bp = $self->notes('build_params');
die "###ERROR### Cannot continue build_params not defined" unless defined($bp);
# check marker
if (! $self->check_build_done_marker) {
# important directories
my $download = 'download';
my $patches = 'patches';
# we are deriving the subdir name from $bp->{title} as we want to
# prevent troubles when user reinstalls the same version of
# Alien::SDL2 with different build options
my $share_subdir = $self->{properties}->{dist_version} . '_' . substr(sha1_hex($bp->{title}), 0, 8);
my $build_out = catfile('sharedir', $share_subdir);
my $build_src = 'build_src';
$self->add_to_cleanup($build_src, $build_out);
# save some data into future Alien::SDL2::ConfigData
$self->config_data('build_prefix', $build_out);
$self->config_data('build_params', $bp);
$self->config_data('build_cc', $Config{cc});
$self->config_data('build_arch', $Config{archname});
$self->config_data('build_os', $^O);
$self->config_data('script', ''); # just to be sure
$self->config_data('config', {}); # just to be sure
$self->config_data('additional_cflags', ''); # just to be sure
$self->config_data('additional_libs', ''); # just to be sure
if($bp->{buildtype} eq 'use_config_script') {
$self->config_data('script', $bp->{script});
# include path trick - adding couple of addititonal locations
$self->set_ld_config($build_out);
$self->config_data('additional_cflags', '-I' . $self->get_path($bp->{prefix} . '/include/smpeg') . ' '.
'-I' . $self->get_path($bp->{prefix} . '/include') . ' ' .
$self->get_additional_cflags);
$self->config_data('additional_libs', $self->get_additional_libs);
}
elsif($bp->{buildtype} eq 'use_prebuilt_binaries') {
# all the following functions die on error, no need to test ret values
$self->fetch_binaries($download);
$self->clean_dir($build_out);
$self->extract_binaries($download, $build_out);
$self->set_config_data($build_out);
$self->set_ld_config($build_out);
}
elsif ( $bp->{buildtype} eq 'build_from_sources' ) {
my $m = '';
if ( $self->notes('travis') && $self->notes('travis') == 1 ) {
# always select option '1'
$m = 1;
}
else {
$m = $self->prompt(
"\nDo you want to see all messages during configure/make (y/n)?",
'n'
);
}
$self->notes('build_msgs', lc($m) eq 'y' ? 1 : 0);
# all the following functions die on error, no need to test ret values
$self->fetch_sources($download);
$self->extract_sources($download, $patches, $build_src);
$self->clean_dir($build_out);
$self->build_binaries($build_out, $build_src);
$self->set_config_data($build_out);
$self->set_ld_config($build_out);
}
# mark sucessfully finished build
$self->touch_build_done_marker;
}
$self->SUPER::ACTION_code;
}
sub fetch_file {
my ($self, $url, $sha1sum, $download) = @_;
die "###ERROR### _fetch_file undefined url\n" unless @{$url}[0];
die "###ERROR### _fetch_file undefined sha1sum\n" unless $sha1sum;
# setting http_proxy environment var if we are within CPAN and this information is available
if(!$ENV{http_proxy} && $ENV{PERL5_CPAN_IS_RUNNING}) {
if(eval('require CPAN::Config; 1') && $CPAN::Config->{http_proxy}) {
$ENV{http_proxy} = $CPAN::Config->{http_proxy};
if($CPAN::Config->{proxy_user} && $CPAN::Config->{proxy_pass} && $CPAN::Config->{http_proxy} !~ m|//.+:.+@|) {
$ENV{http_proxy} =~ s|://|://\Q$CPAN::Config->{proxy_user}\E:\Q$CPAN::Config->{proxy_pass}\E@|;
}
}
}
my $ff = File::Fetch->new(uri => @{$url}[0]);
my $fn = catfile($download, $ff->file);
if (-e $fn) {
print "Checking checksum for already existing '$fn'...\n";
return 1 if $self->check_sha1sum($fn, $sha1sum);
unlink $fn; #exists but wrong checksum
}
my $fullpath;
foreach my $current_url (@{$url})
{
die "###ERROR### _fetch_file undefined url\n" unless $current_url;
print "Fetching '$current_url'...\n";
$ff = File::Fetch->new(uri => $current_url);
$fullpath = $ff->fetch(to => $download);
last if $fullpath;
}
die "###ERROR### Unable to fetch '$ff->file'" unless $fullpath;
if (-e $fn) {
print "Checking checksum for '$fn'...\n";
return 1 if $self->check_sha1sum($fn, $sha1sum);
die "###ERROR### Checksum failed '$fn'";
}
die "###ERROR### _fetch_file failed '$fn'";
}
sub fetch_binaries {
my ($self, $download) = @_;
my $bp = $self->notes('build_params');
$self->fetch_file($bp->{url}, $bp->{sha1sum}, $download);
}
sub fetch_sources {
my ($self, $download) = @_;
my $bp = $self->notes('build_params');
$self->fetch_file($_->{url}, $_->{sha1sum}, $download) foreach (@{$bp->{members}});
}
sub extract_binaries {
my ($self, $download, $build_out) = @_;
# do extract binaries
my $bp = $self->notes('build_params');
( run in 2.842 seconds using v1.01-cache-2.11-cpan-39bf76dae61 )