X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=Porting%2Fmakerel;h=3bfb855655c0cbd158d6caaa8ebe82578d64a054;hb=ba979b3106a5e7f3b2512d1f4e93c681fba7aa9f;hp=72005b48416cf3be31a5e06a88bd55d787f439d6;hpb=48e117bb377f900d5a825f4d5684508055bf832c;p=p5sagit%2Fp5-mst-13.2.git diff --git a/Porting/makerel b/Porting/makerel index 72005b4..3bfb855 100644 --- a/Porting/makerel +++ b/Porting/makerel @@ -20,19 +20,14 @@ die "Must be in root of the perl source tree.\n" open PATCHLEVEL,"; close PATCHLEVEL; -my $patchlevel_h = join "", grep { /^#define/ } @patchlevel_h; +my $patchlevel_h = join "", grep { /^#\s*define/ } @patchlevel_h; print $patchlevel_h; -$patchlevel = $1 if $patchlevel_h =~ /PATCHLEVEL\s+(\d+)/; -$subversion = $1 if $patchlevel_h =~ /SUBVERSION\s+(\d+)/; +$revision = $1 if $patchlevel_h =~ /PERL_REVISION\s+(\d+)/; +$patchlevel = $1 if $patchlevel_h =~ /PERL_VERSION\s+(\d+)/; +$subversion = $1 if $patchlevel_h =~ /PERL_SUBVERSION\s+(\d+)/; die "Unable to parse patchlevel.h" unless $subversion >= 0; -$vers = sprintf("5.%03d", $patchlevel); -$vms_vers = sprintf("5_%03d", $patchlevel); -if ($subversion) { - $vers.= sprintf( "_%02d", $subversion); - $vms_vers.= sprintf( "%02d", $subversion); -} else { - $vms_vers.= " "; -} +$vers = sprintf("%d.%d.%d", $revision, $patchlevel, $subversion); +$vms_vers = sprintf("%d_%d_%d", $revision, $patchlevel, $subversion); # fetch list of local patches my (@local_patches, @lpatch_tags, $lpatch_tags); @@ -41,7 +36,7 @@ my (@local_patches, @lpatch_tags, $lpatch_tags); @lpatch_tags = map { /^\s*,"(\w+)/ } @local_patches; $lpatch_tags = join "-", @lpatch_tags; -$perl = "perl$vers"; +$perl = "perl-$vers"; $reldir = "$perl"; $reldir .= "-$lpatch_tags" if $lpatch_tags; @@ -80,12 +75,13 @@ $cmd = "awk '{print \$1}' MANIFEST | cpio -pdm $relroot/$reldir"; system($cmd) == 0 or die "$cmd failed"; print "\n"; -chdir $relroot or die $!; +chdir "$relroot/$reldir" or die $!; print "Setting file permissions...\n"; -system("find . -type f -print | xargs chmod -w"); -system("find . -type d -print | xargs chmod g-s"); -system("find t -name '*.t' -print | xargs chmod +x"); +system("find . -type f -print | xargs chmod 0444"); +system("find . -type d -print | xargs chmod 0755"); +system("find t ext lib -name '*.t' -print | xargs chmod +x"); +system("find t ext lib -name 'test.pl' -print | xargs chmod +x"); my @exe = qw( Configure configpm @@ -93,29 +89,77 @@ my @exe = qw( installperl installman keywords.pl - myconfig opcode.pl perly.fixer t/TEST - t/*/*.t *.SH vms/ext/Stdio/test.pl vms/ext/filespec.t x2p/*.SH Porting/patchls Porting/makerel + mpeix/nm + mpeix/relink ); system("chmod +x @exe"); + +my @writables = qw( + NetWare/config_H.wc + NetWare/Makefile + keywords.h + opcode.h + opnames.h + pp_proto.h + pp.sym + proto.h + embed.h + embedvar.h + global.sym + pod/perlintern.pod + pod/perlapi.pod + perlapi.h + perlapi.c + ext/ByteLoader/byterun.h + ext/ByteLoader/byterun.c + ext/B/B/Asmdata.pm + ext/Devel/PPPort/PPPort.xs + ext/Devel/PPPort/module2.c + ext/Devel/PPPort/module3.c + regnodes.h + warnings.h + lib/warnings.pm + vms/perly_c.vms + vms/perly_h.vms + win32/Makefile + win32/Makefile.win64 + win32/makefile.mk + win32/config_H.bc + win32/config_H.gc + win32/config_H.vc + wince/config_H.ce + wince/Makefile.ce +); +system("chmod +w @writables"); + +print "Adding CRs to DOSish files...\n"; my @crlf = qw( djgpp/configure.bat + README.ce README.dos README.win32 win32/Makefile + win32/Makefile.win64 win32/makefile.mk + wince/Makefile.ce + wince/README.compile + wince/README.perlce + wince/registry.bat ); -system("perl -pi -e 's/\$/\\r/' @crlf"); +system("perl -pi -e 's/\015*\012/\015\012/' @crlf"); print "\n"; +chdir ".." or die $!; + print "Creating and compressing the tar file...\n"; my $src = (-e $perl) ? $perl : 'perl'; # 'perl' in maint branch $cmd = "tar cf - $reldir | gzip --best > $reldir.tar.gz";