Alien-Box2D
view release on metacpan or search on metacpan
inc/My/Builder.pm view on Meta::CPAN
$ar = "$_/ar" if (!$ar && -x "$_/ar");
$ranlib = "$_/ranlib" if (!$ranlib && -x "$_/ranlib");
}
}
print "Gonna read version info from $srcdir/Common/b2Settings.cpp\n";
open(DAT, "$srcdir/Common/b2Settings.cpp") || die;
my @raw=<DAT>;
close(DAT);
my ($version) = grep(/version\s?=\s?\{[\d\s,]+\}/, @raw);
if ($version =~ /version\s?=\s?\{(\d+)[^\d]+(\d+)[^\d]+(\d+)\}/) {
print STDERR "Got version=$1.$2.$3\n";
$self->notes('build_box2d_version', "$1.$2.$3");
}
chdir $srcdir;
my @cmd = ($self->_get_make, '-f', $makefile, "PREFIX=$prefixdir", 'install');
push @cmd, "CXXFLAGS=$cxxflags" if $cxxflags;
push @cmd, "AR=$ar" if $ar;
push @cmd, "RANLIB=$ranlib" if $ranlib;
push @cmd, "CXX=$cxx" if $cxx;
printf("(cmd: %s)\n", join(' ', @cmd));
$self->config_data('make_command', \@cmd);
$self->do_system(@cmd) or die "###ERROR### [$?] during make ... ";
chdir $self->base_dir();
return 1;
}
sub clean_dir {
my( $self, $dir ) = @_;
if (-d $dir) {
File::Path::rmtree($dir);
File::Path::mkpath($dir);
}
}
sub check_build_done_marker {
my $self = shift;
return (-e 'build_done');
}
sub touch_build_done_marker {
my $self = shift;
require ExtUtils::Command;
local @ARGV = ('build_done');
ExtUtils::Command::touch();
$self->add_to_cleanup('build_done');
}
sub clean_build_done_marker {
my $self = shift;
unlink 'build_done' if (-e 'build_done');
}
sub check_sha1sum {
my ($self, $file, $sha1sum) = @_;
my $sha1 = Digest::SHA->new;
my $fh;
open($fh, $file) or die "###ERROR## Cannot check checksum for '$file'\n";
binmode($fh);
$sha1->addfile($fh);
close($fh);
return ($sha1->hexdigest eq $sha1sum) ? 1 : 0
}
sub find_file {
my ($self, $dir, $re) = @_;
my @files;
$re ||= qr/.*/;
find({ wanted => sub { push @files, rel2abs($_) if /$re/ }, follow => 1, no_chdir => 1 , follow_skip => 2}, $dir);
return @files;
}
sub quote_literal {
my ($self, $txt) = @_;
if ($^O eq 'MSWin32') {
$txt =~ s|"|\\"|g;
return qq("$txt");
}
return $txt;
}
# pure perl implementation of patch functionality
sub apply_patch {
my ($self, $dir_to_be_patched, $patch_file) = @_;
my ($src, $diff);
undef local $/;
open(DAT, $patch_file) or die "###ERROR### Cannot open file: '$patch_file'\n";
$diff = <DAT>;
close(DAT);
$diff =~ s/\r\n/\n/g; #normalise newlines
$diff =~ s/\ndiff /\nSpLiTmArKeRdiff /g;
my @patches = split('SpLiTmArKeR', $diff);
print STDERR "Applying patch file: '$patch_file'\n";
foreach my $p (@patches) {
my ($k) = map{$_ =~ /\n---\s*([\S]+)/} $p;
# doing the same like -p1 for 'patch'
$k =~ s|\\|/|g;
$k =~ s|^[^/]*/(.*)$|$1|;
$k = catfile($dir_to_be_patched, $k);
print STDERR "- gonna patch '$k'\n" if $self->notes('build_debug_info');
open(SRC, $k) or die "###ERROR### Cannot open file: '$k'\n";
$src = <SRC>;
close(SRC);
$src =~ s/\r\n/\n/g; #normalise newlines
my $out = eval { Text::Patch::patch( $src, $p, { STYLE => "Unified" } ) };
if ($out) {
open(OUT, ">", $k) or die "###ERROR### Cannot open file for writing: '$k'\n";
print(OUT $out);
close(OUT);
}
else {
warn "###WARN### Patching '$k' failed: $@";
}
}
}
( run in 0.558 second using v1.01-cache-2.11-cpan-cdf2f3d4e48 )