From 6d12a859bc99ae8fa52ef889c2b818fbf7df7198 Mon Sep 17 00:00:00 2001 From: Wayne Davison Date: Sat, 18 Feb 2006 21:27:54 +0000 Subject: [PATCH] The perl script I use to create new rsync releases. This is an adapted and extended version of an old shell script. --- packaging/release-rsync | 244 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 244 insertions(+) create mode 100755 packaging/release-rsync diff --git a/packaging/release-rsync b/packaging/release-rsync new file mode 100755 index 00000000..8ce661b7 --- /dev/null +++ b/packaging/release-rsync @@ -0,0 +1,244 @@ +#!/usr/bin/perl +use strict; + +# This script expects the directory ~/samba-rsync-ftp to exist and to +# be a copy of the /home/ftp/pub/rsync dir on samba.org. If it is run +# in test mode, it instead expects a dir named ~/tmp/samba-rsync-ftp +# (e.g. copy ~/samba-rsync-ftp into ~/tmp and you can do a trial-run of +# a release without affecting the files in the ~/samba-rsync-ftp dir). +# +# Run this as "release-rsync live" to affect ~/samba-rsync-ftp instead +# of ~/tmp/samba-rsync-ftp. + +use Date::Format; + +my $dest = $ENV{HOME} . '/samba-rsync-ftp'; +my $releasedir = $ENV{HOME} . '/release'; +my $cvsroot = $ENV{CVSROOT} = 'samba.org:/data/cvs'; + +my $ztoday = time2str('%d %b %Y', time); +my $today = $ztoday; +$today =~ s/^0//; + +my $dots = <; +chomp $version; +$version =~ s/[-.]*pre[-.]*/pre/; + +my $cvstag = "release-$version"; +$cvstag =~ s/[.]/-/g; +$cvstag =~ s/pre/-pre/; + +print "Enter the previous version to produce a patch against: "; +my $lastversion = ; +chomp $lastversion; +$lastversion =~ s/[-.]*pre[-.]*/pre/; + +print "Please enter the RPM release number of this release (default 1): "; +my $release = ; +chomp $release; +$release = 1 if $release eq ''; + +my $diffdir; +if ($lastversion =~ /pre/) { + if ($version !~ /pre/) { + die "You should not diff a release version against a pre-release version.\n"; + } + $diffdir = "$dest/old-previews"; +} elsif ($version =~ /pre/) { + $diffdir = $dest; +} else { + $diffdir = "$dest/old-versions"; +} + +my $tarfile = "$dest/rsync-$version.tar.gz"; + +print < "; +$_ = ; + +mkdir($releasedir, 0755) or die $! unless -d $releasedir; +chdir($releasedir) or die $!; + +system "rm -rf rsync rsync-$version rsync-$lastversion"; + +system "cvs checkout -P rsync"; + +chdir('rsync') or die $!; + +print $dots; + +system "./prepare-source && touch proto.h"; + +my @tweak_files = ( glob('packaging/*.spec'), glob('packaging/*/*.spec'), + glob('*.yo'), qw( configure.in configure ) ); +if ($version !~ /pre/) { + push(@tweak_files, qw( NEWS OLDNEWS )); +} +foreach my $fn (@tweak_files) { + open(IN, '<', $fn) or die $!; + undef $/; $_ = ; $/ = "\n"; + close IN; + if ($fn =~ /configure/) { + s/^RSYNC_VERSION.*/RSYNC_VERSION=$version/m; + } elsif ($fn =~ /\.spec/) { + s/^(Version:) .*/$1 $version/m; + s/^(Release:) .*/$1 $release/m; + } elsif ($fn =~ /\.yo/) { + s/^(manpage\([^)]+\)\(\d+\)\()[^)]+(\).*)/$1$today$2/m; + s/^(This man ?page is current for version) \S+ (of rsync)/$1 $version $2/m; + } else { + s/^(NEWS for rsync \Q$version\E) \(UNRELEASED\)\s*$/$1 ($today)\n/m; + s/^\t\S\S\s\S\S\S\s\d\d\d\d(\t\Q$version\E)/\t$ztoday$1/m; + } + open(OUT, '>', $fn) or die $!; + print OUT $_; + close OUT; +} + +system "yodl2man -o rsync.1 rsync.yo"; +system "yodl2man -o rsyncd.conf.5 rsyncd.conf.yo"; +#system "perl -pi -e \"s/\\\\\\'/\\\\&'/g\" rsync.1 rsyncd.conf.5"; + +mkdir('patches/tmp') or die $!; +system "rsync -a --exclude=patches/ --exclude-from=.cvsignore . patches/tmp/cvsdir/"; + +print $dots, $note; + +system "patches/verify-patches -un -an"; + +system "cvs -q diff | egrep -v '^(===============|RCS file: |retrieving revision |Index: )' | less -p '^diff .*'"; + +if ($live) { + print < "; + $_ = ; + + system "cvs commit -m 'Preparing for release of $version'"; + system "cvs tag -F $cvstag ."; +} else { + print "\n**** Skipping cvs commit and tagging in TESTMODE ****\n"; +} + +print < "; +$_ = ; + +print $note; + +system "patches/verify-patches -pun -an"; + +chdir($releasedir) or die $!; + +print $dots; + +mkdir("rsync-$version", 0755) or die $!; +system "rsync -aC --exclude=.cvsignore rsync/ rsync-$version"; + +# When creating a pre-release after a normal release, there's nothing to move. +if ($diffdir ne $dest) { + chdir($dest) or die $!; + + # We need to run this regardless of $lastversion's "pre"ness. */ + foreach my $fn (glob('rsync*pre*.tar.gz*'), glob('rsync*pre*-NEWS')) { + rename($fn, "old-previews/$fn"); + } + system "rm -f rsync*pre*.diffs.gz*"; + + if ($version !~ /pre/) { + foreach my $fn (glob('rsync*.tar.gz*'), glob('rsync*-NEWS')) { + rename($fn, "old-versions/$fn"); + } + + foreach my $fn (glob('rsync*.diffs.gz*')) { + rename($fn, "old-patches/$fn"); + } + } + + chdir($releasedir) or die $!; +} +system "fakeroot tar czf $tarfile rsync-$version"; + +system "tar xzf $diffdir/rsync-$lastversion.tar.gz"; +## TWEAK THE VERSIONS AS DESIRED HERE ## +#mkdir("rsync-$lastversion/support", 0755) or die $!; +#rename("rsync-$lastversion/rsyncstats", "rsync-$lastversion/support/rsyncstats"); +## END ## +system "diff -urN --exclude=patches rsync-$lastversion rsync-$version" + . "| gzip -9 >$dest/rsync-$lastversion-$version.diffs.gz"; + +system "rsync -a rsync/{README,NEWS,OLDNEWS,TODO} $dest"; +unlink("$dest/rsync-$version-NEWS"); +link("$dest/NEWS", "$dest/rsync-$version-NEWS"); +system "rsync -a $cvsroot/CVSROOT/rsync.updates $dest/cvs.log"; + +system "yodl2html -o $dest/rsync.html rsync/rsync.yo"; +system "yodl2html -o $dest/rsyncd.conf.html rsync/rsyncd.conf.yo"; + +system "rm -rf rsync rsync-$version rsync-$lastversion"; + +if ($live) { + chdir($dest) or die $!; + system "gpg -ba rsync-$version.tar.gz"; + system "gpg -ba rsync-$lastversion-$version.diffs.gz"; +} + +print <