summaryrefslogtreecommitdiff
path: root/pat/patnotify.SH
diff options
context:
space:
mode:
authorManoj Srivastava <srivasta@debian.org>2003-12-01 17:11:15 +0000
committerManoj Srivastava <srivasta@debian.org>2003-12-01 17:11:15 +0000
commit371472d9fb6a936149b105a6563a0550d35bdf1a (patch)
tree6d23751e44a7dddf4e29918551f1ea0513352622 /pat/patnotify.SH
Initial import of upstream branch
Initial import of upstream branch git-archimport-id: srivasta@debian.org--2003-primary/dist--upstream--3.70--base-0
Diffstat (limited to 'pat/patnotify.SH')
-rw-r--r--pat/patnotify.SH232
1 files changed, 232 insertions, 0 deletions
diff --git a/pat/patnotify.SH b/pat/patnotify.SH
new file mode 100644
index 0000000..7fc27e9
--- /dev/null
+++ b/pat/patnotify.SH
@@ -0,0 +1,232 @@
+case $CONFIG in
+'')
+ if test -f config.sh; then TOP=.;
+ elif test -f ../config.sh; then TOP=..;
+ elif test -f ../../config.sh; then TOP=../..;
+ elif test -f ../../../config.sh; then TOP=../../..;
+ elif test -f ../../../../config.sh; then TOP=../../../..;
+ else
+ echo "Can't find config.sh."; exit 1
+ fi
+ . $TOP/config.sh
+ ;;
+esac
+case "$0" in
+*/*) cd `expr X$0 : 'X\(.*\)/'` ;;
+esac
+echo "Extracting pat/patnotify (with variable substitutions)"
+cat >patnotify <<!GROK!THIS!
+$startperl
+ eval "exec perl -S \$0 \$*"
+ if \$running_under_some_shell;
+
+# $Id: patnotify.SH,v 3.0.1.9 1997/02/28 16:33:35 ram Exp $
+#
+# Copyright (c) 1991-1993, Raphael Manfredi
+#
+# You may redistribute only under the terms of the Artistic Licence,
+# as specified in the README file that comes with the distribution.
+# You may reuse parts of this distribution only within the terms of
+# that same Artistic Licence; a copy of which may be found at the root
+# of the source tree for dist 3.0.
+#
+# $Log: patnotify.SH,v $
+# Revision 3.0.1.9 1997/02/28 16:33:35 ram
+# patch61: let them know the patch priority and description
+#
+# Revision 3.0.1.8 1995/09/25 09:21:43 ram
+# patch59: now tells users how to directly request for mailed patches
+#
+# Revision 3.0.1.7 1994/10/29 16:43:19 ram
+# patch36: added various escapes in strings for perl5 support
+#
+# Revision 3.0.1.6 1994/06/20 07:11:47 ram
+# patch30: patnotify now includes the e-mail address for requests
+#
+# Revision 3.0.1.5 1994/01/24 14:31:48 ram
+# patch16: now prefix error messages with program's name
+# patch16: don't feed mailer with more than 50 addresses at a time
+# patch16: added ~/.dist_profile awareness
+#
+# Revision 3.0.1.4 1993/08/27 14:40:42 ram
+# patch7: two files were wrongly appended to patsend instead
+#
+# Revision 3.0.1.3 1993/08/25 14:07:43 ram
+# patch6: now asks for recipient list edition by default
+# patch6: new -q option to suppress that
+#
+# Revision 3.0.1.2 1993/08/24 12:48:03 ram
+# patch5: fixed fatal typo in here document
+#
+# Revision 3.0.1.1 1993/08/24 12:19:11 ram
+# patch3: created
+#
+
+\$defeditor='$defeditor';
+\$version = '$VERSION';
+\$patchlevel = '$PATCHLEVEL';
+\$mailer = '$mailer';
+!GROK!THIS!
+cat >>patnotify <<'!NO!SUBS!'
+
+$progname = &profile; # Read ~/.dist_profile
+require 'getopts.pl';
+&usage unless &Getopts("hquV");
+
+if ($opt_V) {
+ print STDERR "$progname $version PL$patchlevel\n";
+ exit 0;
+} elsif ($opt_h) {
+ &usage;
+}
+
+chdir '..' if -d '../bugs';
+
+&readpackage;
+&readusers if $opt_u;
+
+$dest = join(' ', @ARGV);
+$dest .= " $notify" if $opt_u;
+
+&usage unless $dest;
+
+# Offer to edit the address list unless -q
+unless ($opt_q) {
+ select((select(STDOUT), $| = 1)[0]);
+ print "Do you wish to edit the address list? [y] ";
+ $ans = <STDIN>;
+ unless ($ans =~ /^n/i) {
+ @to = split(' ', $dest);
+ &listedit(*to);
+ $dest = join(' ', @to);
+ }
+}
+
+if (-f 'patchlevel.h') {
+ open(PL,"patchlevel.h") || die "$progname: can't open patchlevel.h: $!\n";
+ while (<PL>) {
+ if (/^#define\s+PATCHLEVEL\s+(\d+)/) {
+ $last = $1;
+ }
+ }
+ die "$progname: malformed patchlevel.h file.\n" if $last eq '';
+} else {
+ die "$progname: no patchlevel.h.\n";
+}
+
+@patches = &patseq($last); # Compute patches sequence
+$lastpat = pop(@patches);
+
+warn "$progname: missing last .logs and .mods files\n" if $lastpat eq '';
+
+$missing = $last - $lastpat + 1;
+$these = $missing == 1 ? 'this' : 'these';
+$patches = $missing == 1 ? 'patch' : 'patches';
+$through = $missing == 1 ? $lastpat : "$lastpat thru " . ($lastpat+$missing-1);
+$have = $missing == 1 ? 'has' : 'have';
+$patlist = "$lastpat-"; # They'll get everything up to the end
+
+($Patches = $patches) =~ s/^p/P/;
+$opt = ($mailer =~ /sendmail/) ? '-odq' : '';
+
+chdir 'bugs' || die "$progname: can't cd to bugs: $!\n";
+
+# Find out priority of last patch set
+$priority = 'UNKNOWN';
+open(PATCH, "patch$lastpat") ||
+ die "$progname: can't open patch #$lastpat: $!\n";
+while (<PATCH>) {
+ /^Priority:\s*(\S+)\s*$/ && ($priority = $1);
+}
+close PATCH;
+
+# Look for the .clog<patch #> description and prepare the patch description
+# for inclusion in the notification, so that they can figure out whether
+# they really need that patch set.
+
+if (-f ".clog$lastpat") {
+ open(LOGS, ".clog$lastpat") ||
+ die "$progname: can't open .clog$lastpat: $!\n";
+ $_ = <LOGS> . <LOGS> . <LOGS>; # Skip first three lines
+ $clog = '';
+ while (<LOGS>) {
+ $clog .= $_;
+ }
+ close LOGS;
+} else {
+ warn "$progname: missing last .clog file in bugs directory\n";
+}
+
+print "$progname: sending notification of $missing new $patches to $dest...\n";
+
+fork && exit;
+
+# I hate broken mailers! Bust it up into smaller groups of people...
+@dest = split(' ', $dest);
+while (@smalldest = splice(@dest, 0, 50)) {
+ $to = join(', ', @smalldest); # Sensible To: for sendmail
+ $smalldest = join(' ', @smalldest);
+
+ open(MAILER, "|$mailer $opt $smalldest") ||
+ die "$progname: can't fork $mailer: $!\n";
+ print MAILER
+"To: $to
+Subject: $Patches $through for $package version $baserev $have been released.
+Precedence: bulk
+X-Mailer: dist [version $version PL$patchlevel]
+
+This is just a quick note to let you know that $package version $baserev
+has been recently upgraded and that $patches $through $have been released.
+
+If you are actively using $package, I strongly suggest you upgrade by
+applying $these $patches, whose priority is $priority.
+
+You can fetch $these $patches automatically by sending me the following mail:
+
+ Subject: Command
+ \@SH mailpatch - $package $baserev $patlist
+ ^ note the c
+
+And if you wish to have future patches mailed directly to you, you can add:
+
+ \@SH package - $package $baserev - mailpatches
+
+If you are not interested in receiving any information about future patches,
+please send me the following mail:
+
+ Subject: Command
+ \@SH package - $package $baserev
+";
+ print MAILER
+"
+Following is the $patches description:
+
+$clog" if $clog;
+ print MAILER
+"
+-- $progname speaking for $maintname <$maintloc>.
+";
+ close MAILER;
+}
+
+sub usage {
+ print STDERR <<EOH;
+Usage: $progname [-hquV] [recipients]
+ -h : print this message and exit
+ -q : quick mode, do not offer to edit recipient list
+ -u : add all to-be-notified users
+ -V : print version number and exit
+EOH
+ exit 1;
+}
+
+!NO!SUBS!
+$grep -v '^;#' ../pl/package.pl >>patnotify
+$grep -v '^;#' ../pl/users.pl >>patnotify
+$grep -v '^;#' ../pl/patseq.pl >>patnotify
+$grep -v '^;#' ../pl/editor.pl >>patnotify
+$grep -v '^;#' ../pl/listedit.pl >>patnotify
+$grep -v '^;#' ../pl/tilde.pl >>patnotify
+$grep -v '^;#' ../pl/profile.pl >>patnotify
+chmod +x patnotify
+$eunicefix patnotify