# Tim Bunce, June 1997
use ExtUtils::Manifest qw(fullcheck);
+$ExtUtils::Manifest::Quiet = 1;
+use Getopt::Std;
$|=1;
-$relroot = ".."; # XXX make an option
+
+sub usage { die <<EOF; }
+usage: $0 [ -r rootdir ] [-s suffix ] [ -b ]
+ -r rootdir directory under which to create the build dir and tarball
+ defaults to '..'
+ -s suffix suffix to append to to the perl-x.y.z dir and tarball name
+ defaults to the concatenaion of the local_patches entry
+ in patchlevel.h (or blank, if none)
+ -b make a .bz2 file in addtion to a .gz file
+EOF
+
+my %opts;
+getopts('br:s:', \%opts) or usage;
+@ARGV && usage;
+
+$relroot = defined $opts{r} ? $opts{r} : "..";
die "Must be in root of the perl source tree.\n"
unless -f "./MANIFEST" and -f "patchlevel.h";
$subversion = $1 if $patchlevel_h =~ /PERL_SUBVERSION\s+(\d+)/;
die "Unable to parse patchlevel.h" unless $subversion >= 0;
$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);
$perl = "perl-$vers";
$reldir = "$perl";
+
+$lpatch_tags = $opts{s} if defined $opts{s};
$reldir .= "-$lpatch_tags" if $lpatch_tags;
print "\nMaking a release for $perl in $relroot/$reldir\n\n";
print "Cross-checking the MANIFEST...\n";
($missfile, $missentry) = fullcheck();
-warn "Can't make a release with MANIFEST files missing.\n" if @$missfile;
-warn "Can't make a release with files not listed in MANIFEST.\n" if @$missentry;
+@$missentry
+ = grep {$_ !~ m!^\.git/! and $_ !~ m!(?:/|^)\.gitignore!} @$missentry;
+if (@$missfile ) {
+ warn "Can't make a release with MANIFEST files missing:\n";
+ warn "\t".$_."\n" for (@$missfile);
+}
+if (@$missentry ) {
+ warn "Can't make a release with files not listed in MANIFEST\n";
+ warn "\t".$_."\n" for (@$missentry);
+
+}
if ("@$missentry" =~ m/\.orig\b/) {
# Handy listing of find command and .orig files from patching work.
# I tend to run 'xargs rm' and copy and paste the file list.
print "\n";
# VMS no longer has hardcoded version numbers descrip.mms
-#print "Updating VMS version specific files with $vms_vers...\n";
-#system("perl -pi -e 's/^\QPERL_VERSION = \E\d\_\d+(\s*\#)/PERL_VERSION = $vms_vers$1/' vms/descrip.mms");
-
-
print "Creating $relroot/$reldir release directory...\n";
die "$relroot/$reldir release directory already exists\n" if -e "$relroot/$reldir";
chdir "$relroot/$reldir" or die $!;
+
+my $SEARCH_ROOTS = 't ext lib dist cpan';
+
print "Setting file permissions...\n";
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");
+system("find $SEARCH_ROOTS -name '*.t' -print | xargs chmod +x");
+system("find $SEARCH_ROOTS -name 'test.pl' -print | xargs chmod +x");
my @exe = qw(
Configure
configpm
installman
keywords.pl
opcode.pl
- perly.fixer
t/TEST
*.SH
- vms/ext/Stdio/test.pl
vms/ext/filespec.t
x2p/*.SH
Porting/findrfuncs
Porting/genlog
Porting/makerel
- Porting/p4genpatch
- Porting/patchls
Porting/*.pl
mpeix/nm
mpeix/relink
embed.h
embedvar.h
global.sym
- pod/perlintern.pod
- pod/perlapi.pod
+ overload.c
+ overload.h
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
+ cpan/Devel-PPPort/module2.c
+ cpan/Devel-PPPort/module3.c
+ reentr.c
+ reentr.h
+ regcharclass.h
regnodes.h
warnings.h
lib/warnings.pm
- vms/perly_c.vms
- vms/perly_h.vms
win32/Makefile
+ win32/Makefile.ce
win32/makefile.mk
win32/config_H.bc
win32/config_H.gc
win32/config_H.vc
- wince/config_H.ce
- wince/Makefile.ce
+ utils/Makefile
+ uconfig.h
);
system("chmod +w @writables") == 0
or die "system: $!";
symbian/README
symbian/xsbuild.pl
win32/Makefile
+ win32/Makefile.ce
+ win32/ce-helpers/compile-all.bat
+ win32/ce-helpers/compile.bat
+ win32/ce-helpers/registry.bat
+ win32/distclean.bat
win32/makefile.mk
- wince/Makefile.ce
- wince/compile-all.bat
- wince/README.perlce
- wince/registry.bat
);
system("perl -pi -e 's/\\015*\\012/\\015\\012/' @crlf") == 0
or die "system: $!";
chdir ".." or die $!;
-print "Creating and compressing the tar file...\n";
my $src = (-e $perl) ? $perl : 'perl'; # 'perl' in maint branch
+
+print "Creating and compressing the tar.gz file...\n";
$cmd = "tar cf - $reldir | gzip --best > $reldir.tar.gz";
-system($cmd) == 0
- or die "$cmd failed";
+system($cmd) == 0 or die "$cmd failed";
+
+if ($opts{b}) {
+ print "Creating and compressing the tar.bz2 file...\n";
+ $cmd = "tar cf - $reldir | bzip2 > $reldir.tar.bz2";
+ system($cmd) == 0 or die "$cmd failed";
+}
+
print "\n";
system("ls -ld $perl*");
+print "\n";
+
+for my $sha (qw(sha1 shasum sha1sum)) {
+ if (`which $sha 2>/dev/null`) {
+ system("$sha $perl*.tar.*");
+ last;
+ }
+}