[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH] Remove announce-gen.m4sh and mailnotify.m4sh.
From: |
Gary V. Vaughan |
Subject: |
[PATCH] Remove announce-gen.m4sh and mailnotify.m4sh. |
Date: |
Wed, 1 Sep 2010 12:18:12 +0700 |
>From earlier discussion, there is no need to clutter the
Libtool tree with these scripts, and we can amend our release
process to use the gnulib announce-gen script in due course.
* libltdl/config/announce-gen.m4sh: Removed. This script has
no apparent connection to libtool functionality, and mostly
duplicates the better maintained gnulib announce-gen script.
* libltdl/config/mailnotify.sh: Removed. This script was used
by only clcommit.m4sh and announce-gen.m4sh, both of which are
now removed too.
* Makefile.maint (announce-gen): Target removed.
* bootstrap: Remove the mailnotify regeneration warning.
* HACKING (Release Procedure): Remove references to
announce-gen.
(Alpha release note template, Full release note template):
Reinstated from before announce-gen was introduced.
Okay to push?
Signed-off-by: Gary V. Vaughan <address@hidden>
---
ChangeLog | 14 ++
HACKING | 181 +++++++++++++--
Makefile.maint | 25 --
bootstrap | 10 -
libltdl/config/.cvsignore | 1 -
libltdl/config/.gitignore | 1 -
libltdl/config/announce-gen.m4sh | 464 --------------------------------------
libltdl/config/mailnotify.m4sh | 403 ---------------------------------
8 files changed, 171 insertions(+), 928 deletions(-)
delete mode 100644 libltdl/config/announce-gen.m4sh
delete mode 100644 libltdl/config/mailnotify.m4sh
diff --git a/ChangeLog b/ChangeLog
index d678169..9fcb522 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,19 @@
2010-09-01 Gary V. Vaughan <address@hidden>
+ Remove announce-gen.m4sh and mailnotify.m4sh.
+ * libltdl/config/announce-gen.m4sh: Removed. This script has
+ no apparent connection to libtool functionality, and mostly
+ duplicates the better maintained gnulib announce-gen script.
+ * libltdl/config/mailnotify.sh: Removed. This script was used
+ by only clcommit.m4sh and announce-gen.m4sh, both of which are
+ now removed too.
+ * Makefile.maint (announce-gen): Target removed.
+ * bootstrap: Remove the mailnotify regeneration warning.
+ * HACKING (Release Procedure): Remove references to
+ announce-gen.
+ (Alpha release note template, Full release note template):
+ Reinstated from before announce-gen was introduced.
+
Remove clcommit.m4sh.
* clcommit.m4sh: Removed. This script was written to help keep
ChangeLog and commit messages in sync when committing to CVS,
diff --git a/HACKING b/HACKING
index e079e4b..b462c98 100644
--- a/HACKING
+++ b/HACKING
@@ -687,38 +687,171 @@ or obtained by writing to the Free Software Foundation,
Inc.,
doc/manual using cvs to here:
<yourusername>@cvs.savannah.gnu.org:/webcvs/libtool
-* In the build directory, run `Make -f[../]Makefile.maint announce-gen'.
+* Write a release announcement, and post it to address@hidden' and
+ address@hidden' with the Reply-To header set to
+ address@hidden'. Stable releases should also be announced
+ on address@hidden'.
-* Make sure the source directory has an appropriate .announcerc, along
- the lines of:
+* Post a copy of your release announcement to savannah news:
+ https://savannah.gnu.org/news/submit.php?group=libtool
+ which will automatically propogate to http://planet.gnu.org.
- --bootstrap-tools='autoconf,automake'
- --gpg-key-id={the id of the key you signed the tarballs with}
- --header 'From: {your name} <{your email address}>
- --header 'To: Libtool List <address@hidden>'
- --header 'Cc: Autotools Announce List <address@hidden>'
- --header 'Reply-To: Libtool Bugs <address@hidden>'
- --message 'GNU Libtool hides the complexity of using shared'
- --message 'libraries behind a consistent, portable interface.'
- --message 'GNU Libtool ships with GNU libltdl, which hides the'
- --message 'complexity of loading dynamic runtime libraries'
- --message '(modules) behind a consistent, portable interface.'
- --signature
-* Check the release announcement with:
+13. Alpha release note template
+===============================
- ./announce-gen -r -o --prev=LASTRELEASE alpha
+To: address@hidden, address@hidden
+Reply-To: address@hidden
+Subject: GNU Libtool @VERSION@ released (alpha release).
- or for a stable release:
+The Libtool Team is pleased to announce alpha release @VERSION@ of GNU
+Libtool.
- ./announce-gen -r -o -h 'Cc: address@hidden' --prev=LASTRELEASE stable
+GNU Libtool hides the complexity of using shared libraries behind a
+consistent, portable interface. GNU Libtool ships with GNU libltdl,
+which hides the complexity of loading dynamic runtime libraries
+(modules) behind a consistent, portable interface.
- When you're happy with the announcement text, post it by rerunning the
- command with `-p' instead of `-o'.
+Here are the compressed sources:
-* Post a copy of the release announcement to savannah news:
- https://savannah.gnu.org/news/submit.php?group=libtool
- which will automatically propogate to http://planet.gnu.org.
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@.tar.gz
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@.tar.bz2
+
+Here are the xdeltas and diffs against address@hidden@:
+
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@address@hidden@.diff.gz
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@address@hidden@.xdelta
+
+Here are the gpg detached signatures:
+
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@.tar.gz.sig
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@.tar.bz2.sig
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@address@hidden@.diff.gz.sig
+ ftp://alpha.gnu.org/gnu/libtool/address@hidden@address@hidden@.xdelta.sig
+
+You should download the signature named after any tarball you download,
+and then verify its integrity with, for example:
+
+ gpg --verify address@hidden@.tar.gz.sig
+
+Here are the MD5 and SHA1 checksums:
+
+ @MD5SUM@ address@hidden@.tar.gz
+ @MD5SUM@ address@hidden@.tar.bz2
+ @MD5SUM@ address@hidden@address@hidden@.diff.gz
+ @MD5SUM@ address@hidden@address@hidden@.xdelta
+ @SHA1SUM@ address@hidden@.tar.gz
+ @SHA1SUM@ address@hidden@.tar.bz2
+ @SHA1SUM@ address@hidden@address@hidden@.diff.gz
+ @SHA1SUM@ address@hidden@address@hidden@.xdelta
+
+This release has @address@hidden
+
+This release was bootstrapped with @BOOTSTRAP_TOOLS_WITH_VERSIONS@,
+but is useable with @COMPATIBLE_AUTOTOOL_VERSIONS@ in your own
+projects.
+
+Alternatively, you can fetch the unbootstrapped source code with
+git by using the following command:
+
+ $ git clone git://git.savannah.gnu.org/libtool.git
+ $ cd libtool
+ $ git checkout @GIT_RELEASE_TAG@
+
+You will then need to have recent (possibly as yet unreleased) versions
+of Automake and Autoconf installed to bootstrap the checked out
+sources yourself.
+
+New in @VERSION@: @RELEASE_DATE@
+
+ @EXCERPT_FROM_NEWS_FILE@
+
+Please report bugs to <address@hidden>, along with the verbose
+output of any failed test groups, and the output from `./libtool --config.'
+The README file explains how to capture the verbose test output.
+
+
+
+14. Full release note template
+==============================
+
+To: address@hidden
+Cc: address@hidden, address@hidden
+Reply-To: address@hidden
+Subject: GNU Libtool @VERSION@ released.
+
+The Libtool Team is pleased to announce the release of GNU Libtool
address@hidden@.
+
+GNU Libtool hides the complexity of using shared libraries behind a
+consistent, portable interface. GNU Libtool ships with GNU libltdl,
+which hides the complexity of loading dynamic runtime libraries
+(modules) behind a consistent, portable interface.
+
+This release has @address@hidden
+
+New in @VERSION@: @RELEASE_DATE@
+
+ @EXCERPT_FROM_NEWS_FILE@
+
address@hidden@ is available now from ftp.gnu.org, along with
+diffs and xdeltas against address@hidden@
+that are also available from ftp.gnu.org. Please
+use a mirror to reduce stress on the main gnu machine:
+
+ http://www.gnu.org/order/ftp.html
+
+Here are the compressed sources:
+
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@.tar.gz
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@.tar.bz2
+
+Here are the xdeltas and diffs against address@hidden@:
+
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@address@hidden@.diff.gz
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@address@hidden@.xdelta
+
+Here are the gpg detached signatures:
+
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@.tar.gz.sig
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@.tar.bz2.sig
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@address@hidden@.diff.gz.sig
+ ftp://ftp.gnu.org/gnu/libtool/address@hidden@address@hidden@.xdelta.sig
+
+You should download the signature named after any tarball you download,
+and then verify its integrity with, for example:
+
+ gpg --verify address@hidden@.tar.gz.sig
+
+Here are the MD5 and SHA1 checksums:
+
+ @MD5SUM@ address@hidden@.tar.gz
+ @MD5SUM@ address@hidden@.tar.bz2
+ @MD5SUM@ address@hidden@address@hidden@.diff.gz
+ @MD5SUM@ address@hidden@address@hidden@.xdelta
+ @SHA1SUM@ address@hidden@.tar.gz
+ @SHA1SUM@ address@hidden@.tar.bz2
+ @SHA1SUM@ address@hidden@address@hidden@.diff.gz
+ @SHA1SUM@ address@hidden@address@hidden@.xdelta
+
+This release was bootstrapped with @BOOTSTRAP_TOOLS_WITH_VERSIONS@,
+but is useable with @COMPATIBLE_AUTOTOOL_VERSIONS@ in your own
+projects.
+
+Alternatively, you can fetch the unbootstrapped source code with
+git by using the following command:
+
+ $ git clone git://git.savannah.gnu.org/libtool.git
+ $ cd libtool
+ $ git checkout @GIT_RELEASE_TAG@
+
+You will then need to have the latest release versions of Automake
+(@AUTOMAKE_VERSION@) and Autoconf (@AUTOCONF_VERSION@) installed to
+bootstrap the checked out sources yourself.
+
+Please report bugs to <address@hidden>, along with the verbose
+output of any failed test groups, and the output from `./libtool --config.'
+The README file explains how to capture the verbose test output.
--
Copyright (C) 2004, 2005, 2006, 2007, 2008, 2010 Free Software
diff --git a/Makefile.maint b/Makefile.maint
index 15d5a14..64abde6 100644
--- a/Makefile.maint
+++ b/Makefile.maint
@@ -36,31 +36,6 @@ Makefile:
TEXI2HTML = texi2html
-announce-gen: $(auxdir)/announce-gen.m4sh $(auxdir)/getopt.m4sh
- $(timestamp); \
- rm -f announce-gen announce-gen.in announce-gen.tmp; \
- $(M4SH) -B $(top_srcdir)/$(auxdir)
$(top_srcdir)/$(auxdir)/announce-gen.m4sh > announce-gen.in; \
- $(edit) -e "s,@TIMESTAMP\@,$$TIMESTAMP,g" \
- -e "s,@LASTRELEASE\@,$(LASTRELEASE),g" \
- -e "s,@top_srcdir\@,$(top_srcdir),g" \
- announce-gen.in > announce-gen.tmp; \
- chmod a+x announce-gen.tmp; \
- chmod a-w announce-gen.tmp; \
- mv -f announce-gen.tmp announce-gen; \
- rm -f announce-gen.in
-
-$(srcdir)/$(auxdir)/mailnotify: $(auxdir)/mailnotify.m4sh
- $(timestamp); \
- cd $(srcdir)/$(auxdir); \
- rm -f mailnotify mailnotify.in mailnotify.tmp; \
- $(M4SH) -B . mailnotify.m4sh > mailnotify.in; \
- $(edit) -e "s,@TIMESTAMP\@,$$TIMESTAMP,g" \
- mailnotify.in > mailnotify.tmp; \
- chmod a+x mailnotify.tmp; \
- chmod a-w mailnotify.tmp; \
- mv -f mailnotify.tmp mailnotify; \
- rm -f mailnotify.in
-
.PHONY: git-release
git-release: version-check prev-tarball check-news fetch git-dist diffs
web-manual
@tarname="$(PACKAGE)-$(VERSION).tar.gz"; \
diff --git a/bootstrap b/bootstrap
index 82828db..78b4d30 100755
--- a/bootstrap
+++ b/bootstrap
@@ -186,14 +186,4 @@ for macro in LT_INIT AC_PROG_LIBTOOL AM_PROG_LIBTOOL; do
else :; fi
done
-# Commit script caveat:
-cat <<EOF
-WARNING: You might want to regenerate \`$auxdir/mailnotify'
-WARNING: after you have run \`configure' to discover the real whereabouts
-WARNING: of \`sed', \`grep' etc. like this:
-WARNING:
-WARNING: rm -f commit $auxdir/mailnotify
-WARNING: make -f Makefile.maint ./commit ./$auxdir/mailnotify
-EOF
-
exit 0
diff --git a/libltdl/config/.cvsignore b/libltdl/config/.cvsignore
index 27981a3..1529432 100644
--- a/libltdl/config/.cvsignore
+++ b/libltdl/config/.cvsignore
@@ -11,4 +11,3 @@ depcomp
compile
config.guess
config.sub
-mailnotify
diff --git a/libltdl/config/.gitignore b/libltdl/config/.gitignore
index a3959de..9beea85 100644
--- a/libltdl/config/.gitignore
+++ b/libltdl/config/.gitignore
@@ -9,4 +9,3 @@ depcomp
compile
config.guess
config.sub
-mailnotify
diff --git a/libltdl/config/announce-gen.m4sh b/libltdl/config/announce-gen.m4sh
deleted file mode 100644
index 777ce9b..0000000
--- a/libltdl/config/announce-gen.m4sh
+++ /dev/null
@@ -1,464 +0,0 @@
-AS_INIT[]m4_divert_push([HEADER-COPYRIGHT])
-# announce-gen (GNU @PACKAGE@) version 1.0
-# Written by Gary V. Vaughan
-# based on a perl script by Jim Meyering
-
-# Copyright (C) 2010 Free Software Foundation, Inc.
-# This is free software; see the source for copying conditions. There is NO
-# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-
-# gen-announce is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# gen-announce is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with clcommit; see the file COPYING. If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html,
-# or obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-
-# Usage: $progname {-o|-p} [OPTIONS]... [--] RELEASE-TYPE [TO-ADDRESS]...
-
-# -b file --blurb=FILE read announcement blurb from FILE
-# --bootstrap-tools=LIST a comma-separated list of tools, e.g.
-# autoconf,automake,bison,gnulib
-# --current-version=VER override current release version number
-# --debug enable verbose shell tracing
-# --gpg-key-id=ID gnupg ID of signature key for release files
-# -h STRING --header=STRING insert mail header into announcement
-# -m STRING --message=STRING insert into message blurb for announcement
-# -c --no-print-checksums do not emit MD5 and SHA1 checksums
-# -o --output output to stdout
-# --package-name=NAME override default package name
-# -p --post post the announcement directly
-# --previous-version=VER previous release version number
-# -r [FILE] --rcfile[=FILE] read options from FILE [./.announcerc]
-# --signature[=FILE] append FILE to post [~/.signature]
-# --url-directory=URL download url directory for released files
-# [ftp://ftp.gnu.org/gnu/<package-name>]
-# -v --verbose run in verbose mode
-# --version print version information
-# -? --help print short or long help message
-
-# In output mode, selected by `-o', a release note is printed on stdout.
-
-# In post mode, the release note is displayed in $PAGER, (giving you the
-# chance to make changes, and add headers) before posting to any every
-# TO-ADDRESS given on the command line, as well as any addresses added
-# to `To:', `Cc:' and `Bcc:' headers during editing.
-
-# The `--rcfile' option points to a file with other option settings, one
-# on each line. For example:
-#
-# --bootstrap-tools='autoconf, automake'
-# --gpg-key-id=2983D606
-# --header 'From: "Gary V. Vaughan" <address@hidden>'
-# --header 'To: Libtool List <address@hidden>'
-# --header 'Cc: Autotools Announce List <address@hidden>'
-# --header 'Reply-To: Libtool Bugs <address@hidden>'
-# --message 'GNU Libtool hides the complexity of using shared'
-# --message 'libraries behind a consistent, portable interface.'
-# --message 'GNU Libtool ships with GNU libltdl, which hides the'
-# --message 'complexity of loading dynamic runtime libraries'
-# --message '(modules) behind a consistent, portable interface.'
-# --signature
-#
-# This is the .announcerc for GNU Libtool. Announce-gen is pretty
-# smart about picking defaults for package-name and current-version
-# and often guesses previous-version correctly too. So, typically a
-# release note can be posted with:
-#
-# ./$progname -r -p -h 'Cc: address@hidden' --prev=<LASTRELEASE> stable
-#
-# When that's producing a good announcement, it can be posted by using
-# the same arguments again, but for `-p' instead of `-o'
-
-# Report bugs to <address@hidden>
-
-: ${DU="du"}
-: ${MAILNOTIFY="mailnotify"}
-: ${MD5SUM="md5"}
-: ${SHA1SUM="shasum"}
-
-PROGRAM=announce-gen
-
-m4_divert_pop
-m4_include([getopt.m4sh])
-
-M4SH_VERBATIM([[
-top_srcdir=`cd "@top_srcdir@" && pwd`
-test -d "$top_srcdir" || top_srcdir='@top_srcdir@'
-
-# Initialisation:
-mailnotify_flags=
-package_name="@PACKAGE@"
-sendmail_to=
-valid_release_types='alpha,beta,release-candidate,stable'
-
-# try to find out whether read supports -r
-if echo bt | tr b '\\' | { read -r line; test "X$line" = 'X\t'; } 2>/dev/null
-then
- read_r='read -r'
-else
- read_r=read
-fi
-]])
-
-dnl SHORT LONG DEFAULT INIT
-dnl ----------------------------------------------------------------------
-M4SH_GETOPTS(
- address@hidden, [--blurb], [],
[],
- [h;], [--header], [],
[],
- [m;], [--message|--msg], [],
[],
- [o], [--output], [], [],
- [p], [--post], [], [],
- address@hidden,[--rcfile],
[$top_srcdir/.announcerc], [
- # The funny quoting allows keeping one option per line in $opt_rcfile:
- eval set dummy `echo \`cat $opt_rcfile\` '${1+"[$]@"}'`
- shift],
- [v], [--verbose], [], [
- mailnotify_flags="${mailnotify_flags+$mailnotify_flags }$opt"],
- [!], [--bootstrap-tools|--bootstrap|--boots], [], [
- for tool in `echo "$optarg"|$SED 's|,| |g'`; do
- ($tool --version) >/dev/null 2>&1 || {
- func_error "$opt \`$optarg' does not respond to --version
option."
- cmd_exit=exit
- }
- done],
- [!], [--current-version|--current|--curr], address@hidden@],
[],
- [!], [--gpg-key-id|--gpg], [], [],
- [], [--no-print-checksums], [], [],
- [!], [--previous-version|--previous|--prev], address@hidden@], [],
- [!], [--release-type], [], [],
- address@hidden, [--signature],
[$HOME/.signature], [],
- [!], [--url-directory], [], [],
- [
- # validate $opt_gpg_key_id
- test -n "$opt_gpg_key_id" || {
- func_error "you must specify a key with --gpg-key-id."
- exit_cmd=exit
- }
-
- # validate $opt_bootstrap_tools
- test -n "$opt_bootstrap_tools" || {
- func_error "you must specify some tools with --bootstrap-tools."
- exit_cmd=exit
- }
-
- # validate $opt_blurb and $opt_message
- test -n "$opt_blurb" && test -n "$opt_message" && {
- func_error "you can specify only one of --blurb and --message."
- exit_cmd=exit
- }
-
- # validate $opt_output and $opt_post
- $opt_output && $opt_post && {
- func_error "you can specify only one of --output and --post."
- exit_cmd=exit
- }
- $opt_output || $opt_post || {
- func_error "you must specify either --output or --post."
- exit_cmd=exit
- }
-
- # validate $opt_release_type
- test -n "$opt_release_type" || {
- test [$]# -gt 0 || { func_error "no release type specified.";
exit_cmd=exit; }
- opt_release_type="[$]1"; shift
- }
- case ,$valid_release_types, in *,$opt_release_type,*) ;;
- *) func_error "\`$opt_release_type': invalid release type.";
exit_cmd=exit ;;
- esac
-
- # validate $url_directory
- test -n "$url_directory" || {
- case $opt_release_type in
- stable) url_directory="ftp://ftp.gnu.org/gnu/$package_name" ;;
- *) url_directory="ftp://alpha.gnu.org/gnu/$package_name" ;;
- esac
- }
-
- # pass trace argument along to mailnotify too
- test "$opt_debug" != ":" &&
- mailnotify_flags="${mailnotify_flags+$mailnotify_flags }--debug"
-
- # validate remaining command line args as destination addresses
- for address
- do
- func_quote_for_eval "$address"
- sendmail_to="${sendmail_to+$sendmail_to }$func_quote_for_eval_result"
- done
-])
-
-M4SH_VERBATIM([[
-# Bail out on command errors!
-set -e
-
-# func_print_changelog_deltas
-func_print_changelog_deltas ()
-{
- $opt_debug
-
- # FIXME: Jim's announce-gen does something with ChangeLogs
- # and cvs diff. We don't use CVS, and perl makes
- # my eyes bleed... maybe I'll write this function
- # one day.
- :
-}
-
-
-# func_print_checksums title filename...
-func_print_checksums ()
-{
- $opt_debug
-
- my_title="$1"; shift
-
- test -n "$1" && {
- echo
- echo "Here are the $my_title:"
- echo
- for my_sum in $MD5SUM $SHA1SUM; do
- for my_filename in ${1+"$@"}; do
- my_line=`$my_sum $my_filename`
- my_hash=`expr "$my_line" : '.*\([0-9a-f]\{40\}\)' || :`
- test -n "$my_hash" || my_hash=`expr "$my_line" :
'.*\([0-9a-f]\{32\}\)'`" "
- echo " $my_hash $my_filename"
- done
- done
- }
-
- # To stop bash exiting if test fails
- :
-}
-
-
-# func_print_locations title url files
-func_print_locations ()
-{
- $opt_debug
-
- test -n "$3" && {
- echo
- echo "Here are the $1:"
- echo
- for my_file in $3; do
- my_size=`$DU -h $my_file|sed 's,[bB]*[ ].*$,,'`
- echo " $2/$my_file (${my_size}B)"
- done
- }
-
- # To stop bash exiting if test fails
- :
-}
-
-
-# func_print_news_deltas
-func_print_news_deltas ()
-{
- $opt_debug
-
- my_news_file="$top_srcdir/NEWS"
- my_skipping=:
-
- # reset the field separator to prevent whitespace removal by 'read'
- save_IFS="$IFS"
- IFS=
-
- echo
- cat $my_news_file |
- while read line; do
- case $line in
- "New in $opt_current_version "*:)
- my_skipping=false
- echo "$line"
- ;;
- "New in "*:)
- my_skipping=:
- ;;
- *)
- $my_skipping || echo "$line"
- ;;
- esac
- done
-
- IFS="$save_IFS"
-}
-
-
-# func_tool_versions toolname...
-func_print_tool_versions ()
-{
- $opt_debug
-
- test -n "$1" && {
- echo
- echo "This release was bootstrapped with the following tools:"
- echo
- for my_tool in ${1+"$@"}; do
- my_tool_version=`$my_tool --version|sed 's,^.* ,,g;1q'`
- echo " $my_tool-$my_tool_version"
- done
- }
-
- # To stop bash exiting if test fails
- :
-}
-
-
-
-## ----- ##
-## main. ##
-## ----- ##
-
-{
- # Neutralize the locale, so that, for instance, "du" does not
- # issue "1,2" instead of "1.2", which confuses our regexps.
- LC_ALL=C
- export LC_ALL
-
- # Secure directory for temporary files
- tmp_dir="`func_mktempdir`"
- trap '$RM -r "$tmp_dir"; exit $EXIT_FAILURE' 1 2 15
-
- # Save any header or post blurb for mailnotify
- header_file="$tmp_dir/headers"
- blurb_file="$tmp_dir/blurb"
-
- test -n "$opt_header" && echo "$opt_header" > "$header_file"
- test -n "$opt_message" && echo "$opt_message" > "$blurb_file"
- test -n "$opt_blurb" && cat "$opt_blurb" > "$blurb_file"
-
- archive_suffixes='tar.gz tar.bz2 tar.lzma tar.xz'
- diff_suffixes='diff.gz diff.bz2 diff.lzma diff.xz xdelta'
-
- # Ensure there is something to announce!
- for suffix in $archive_suffixes; do
- candidate="$package_name-$opt_current_version.$suffix"
- candidates="${candidates+$candidates, }$candidate"
- test -r "$candidate" || continue
- tarballs="${tarballs+$tarballs }$candidate"
- done
- for suffix in $diff_suffixes; do
-
candidate="$package_name-$opt_previous_version-$opt_current_version.$suffix"
- candidates="${candidates+$candidates, }$candidate"
- test -r "$candidate" || continue
- compressed_diffs="${compressed_diffs+$compressed_diffs }$candidate"
- done
- test -n "$tarballs$compressed_diffs" ||
- func_fatal_error "none of $candidates were found."
-
- # Signature files
- signed_files="$tarballs $compressed_diffs"
- for signed in $signed_files; do
- sig_files="${sig_files+$sig_files }$signed.sig"
- done
-
- # Displaying or posting the announcement?
- if $opt_post; then
- notify_file="$tmp_dir/post"
- exec 3>$notify_file
- else
- exec 3>&1
- fi
-
- {
- echo "Subject: $package_name $opt_current_version released
($opt_release_type)"
- test -f "$header_file" && cat "$header_file"
- echo
- test -f "$blurb_file" && cat "$blurb_file"
- func_print_locations "compressed sources" "$url_directory" "$tarballs"
- func_print_locations "diffs against $package_name $opt_previous_version"
"$url_directory" "$compressed_diffs"
- func_print_locations "GPG detached signatures[1]" "$url_directory"
"$sig_files"
-
- $opt_print_checksums &&
- func_print_checksums "MD5 and SHA1 checksums[2]" $tarballs
$compressed_diffs
-
- case $url_directory in
- *"gnu.org"*)
- echo
- echo 'To reduce load on the main server, please one of the
mirrors listed at:'
- echo
- echo ' http://www.gnu.org/order/ftp.html'
- ;;
- esac
-
- cat <<EOF
-
-[1] You can use the above signature files to verify that the
- corresponding file (without the .sig suffix) is the same
- file that was released by the owner of it's GPG key ID.
- First be sure to download both the .sig file and the
- corresponding file. Then run a cammand like this:
-
- gpg --verify `echo "$tarballs" | sed -e 's, .*$,,g'`.sig
-
- If that command fails because you don't have the required
- public key, then run this command to import it:
-
- gpg --keyserver keys.gnupg.net --recv-keys $opt_gpg_key_id
-
- and rerun the \`gpg --verify' command.
-EOF
-
- $opt_print_checksums && cat <<EOF
-
-[2] You can use either of the above checksum files to verify
- that the corresponding file is complete and correct. To
- confirm that the file you downloaded has a checksum that
- matches the release note, compare it against the output
- one of the following commands:
-
- md5sum `echo "$tarballs" | sed -e 's, .*$,,g'`
- shasum `echo "$tarballs" | sed -e 's, .*$,,g'`
-
- (the name of the command sometimes varies between
- different operating systems).
-EOF
-
- func_print_tool_versions $tool_list
- func_print_news_deltas
- func_print_changelog_deltas
-
- echo 'Enjoy!'
- } >&3
-
- $opt_post && {
- test -f "$top_srcdir/libltdl/config/$MAILNOTIFY" &&
- MAILNOTIFY="$top_srcdir/libltdl/config/$MAILNOTIFY"
- test -f "$MAILNOTIFY" ||
- func_fatal_error "$MAILNOTIFY: file not found."
-
- ${PAGER-more} "$notify_file" || break
-
- sleep 1 # give the user some time for a ^C
-
- # Break out the headers
- header_file="$tmp_dir/headers"
- $SED -n '/[A-Z][a-zA-Z0-9-]*: /p;/^$/q' "$notify_file" > "$header_file"
-
- my_mail_body="`$SED '1,/^$/d' $notify_file`"
- echo "$my_mail_body" > "$notify_file"
-
- func_verbose "mailing release announcement to \"$sendmail_to\""
- func_show_eval "$MAILNOTIFY $mailnotify_flags \
- --headers='$header_file' \
- -m 'text/plain' -f '$notify_file' -- $sendmail_to"
- }
-}
-
-$RM -r "$tmp_dir"
-
-exit $EXIT_SUCCESS
-
-# Local Variables:
-# mode:shell-script
-# sh-indentation:2
-# End:
-]])
diff --git a/libltdl/config/mailnotify.m4sh b/libltdl/config/mailnotify.m4sh
deleted file mode 100644
index bbf3e03..0000000
--- a/libltdl/config/mailnotify.m4sh
+++ /dev/null
@@ -1,403 +0,0 @@
-AS_INIT[]m4_divert_push([HEADER-COPYRIGHT])
-# mailnotify (GNU @PACKAGE@) version 1.0
-# Written by Gary V. Vaughan <address@hidden>
-
-# Copyright (C) 2004, 2006, 2010 Free Software Foundation, Inc.
-# This is free software; see the source for copying conditions. There is NO
-# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
-
-# Mailnotify is free software; you can redistribute it and/or modify
-# it under the terms of the GNU General Public License as published by
-# the Free Software Foundation; either version 2 of the License, or
-# (at your option) any later version.
-#
-# Mailnotify is distributed in the hope that it will be useful, but
-# WITHOUT ANY WARRANTY; without even the implied warranty of
-# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-# GNU General Public License for more details.
-#
-# You should have received a copy of the GNU General Public License
-# along with mailnotify; see the file COPYING. If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html,
-# or obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-
-# Usage: $progname [OPTIONS]...
-#
-# -x --debug enable verbose shell tracing
-# --dry-run don't actually post the mime message
-# -f FILE --filename=FILE content of this part
-# -h FILE --headers=FILE read additional headers from FILE
-# -m TYPE --mime-type=TYPE mime-type of this part
-# -o FILE --output-file=FILE output to FILE instead of sending
-# -v --verbose run in verbose mode
-# --version print version information
-# -? --help print short or long help message
-
-# Assemble a (possibly multi-part) mime message and hand it to the local
-# sendmail for onward delivery. MUAs tend to mangle patch attachments in
-# various ways: not setting the mime-type correctly, line wrapping the
-# patch itself, escaping certain values, etc. This script is designed to
-# make it easier to send a patch as a MIME attachment, though it is general
-# enough that it might be useful otherwise.
-
-# For example to send a patch as an attachment, assuming the patch itself
-# is in PATCHFILE:
-#
-# echo 'From: address@hidden' > headers
-# echo 'To: address@hidden' >> headers
-# echo 'Subject: FYI: PATCHFILE' >> headers
-# echo 'Cc: address@hidden' >> headers
-# echo 'Applied this patch to HEAD' > body
-# $progname -h headers -f body -m text/plain -f PATCHFILE -m text/x-patch
-#
-# There is no set order or requirement for mail headers in the headers
-# file, though you will obviously need someone's address in 'To:', and
-# it's not polite to omit the 'Subject:' header...
-
-# You will probably find using this script in conjunction with clcommit
-# saves you a lot of typing.
-
-# Report bugs to <address@hidden>
-
-: ${HOST=`hostname`}
-: ${SENDMAIL=sendmail}
-
-PROGRAM=mailnotify
-
-m4_divert_pop
-m4_include([getopt.m4sh])
-
-M4SH_VERBATIM([[
-sed_mail_address='s,^.*<\(.*\)>.*$,\1,'
-]])
-
-dnl SHORT LONG DEFAULT INIT
-dnl ----------------------------------------------------------------------
-dnl There are several options supported below for backwards compatibility,
-dnl but which are not mentioned in the help.
-M4SH_GETOPTS(
- [C^!], [--carbon-copy], [], [],
- [F^!], [--from], [], [],
- address@hidden, [--filename], [],
[],
- address@hidden, [--headers], [],
[],
- [m+!], [--mime-type], [], [
- case [$]1 in
- text/*) ;;
- */*) func_error "\`[$]1': only text/* mime-types supported"
- ;;
- *) func_error "invalid mime-type, \`[$]1'"
- exit_cmd=exit
- ;;
- esac],
- [n], [], [], [],
- [o!], [--output-file], [],
[],
- [s^!], [--subject], [], [],
- [v], [--verbose], [], [],
- [], [--dry-run|--dryrun], [], [],
- [
- # ensure destination address(es) available
- test [$]# -gt 0 ||
- grep '^\(To\|Cc\|Bcc\): ' "${opt_headers-nosuchfile}" >/dev/null 2>&1 ||
- func_fatal_help "no destination address"
-
- # validate headers
- test "$opt_headers" && {
- test -n "$opt_carbon_copy" && grep "^Cc: *" "$opt_headers" >/dev/null 2>&1
&& {
- func_error "specify \`Cc:' in either \`$opt_headers' or with
\`--carbon-copy'."
- exit_cmd=exit
- }
- test -n "$opt_from" && grep "^From: *" "$opt_headers" >/dev/null 2>&1 && {
- func_error "specify \`From:' in either \`$opt_headers' or with
\`--from'."
- exit_cmd=exit
- }
- test -n "$opt_subject" && grep "^Subject: *" "$opt_headers" >/dev/null
2>&1 && {
- func_error "specify \`Subject:' in either \`$opt_headers' or with
\`--subject'."
- exit_cmd=exit
- }
- }
-
- # validate mime parts
- if test "${opt_mime_type_num-0}" -ne "${opt_filename_num-0}"; then
- func_fatal_error "One part is incomplete -- each part needs a filename and
a mime-type"
- fi
- if test -z "$opt_output_file"; then
- test -f "$opt_headers" || if test -z "$opt_subject" ||
- eval test -z \"\$opt_mime_type_$opt_mime_type_num\" ||
- eval test -z \"\$opt_filename_$opt_filename_num\"; then
- func_fatal_error "if output is not directed to a file -s, -f, and -m are
all required"
- fi
- else
- eval test -n \"\$opt_filename_$opt_filename_num\" ||
- func_fatal_error "-f is required."
- eval test -n \"\$opt_mime_type_$opt_mime_type_num\" ||
- func_fatal_error "with output directed to a file, -m is required"
- fi
-
- # validate $opt_dry_run
- $opt_dry_run && SENDMAIL="echo $SENDMAIL"
-])
-
-M4SH_VERBATIM([[
-# Bail out on command errors!
-set -e
-
-# func_headers outfile destination
-# Generate common headers to OUTFILE, where DESTINATION is a comma
-# separated list of fully qualified destination addresses.
-func_headers ()
-{
- $opt_debug
-
- my_outfile="$1"
- my_destination="$2"
- my_sed_version_no='
- /^# '$PROGRAM' (GNU / {
- s/^# .*version //
- p
- }
- d'
-
- $opt_dry_run || {
- echo "User-Agent: $PROGRAM/`$SED \"$my_sed_version_no\" < $progpath`"
- echo "MIME-Version: 1.0"
-
- # Deprecated command line options take precedence at the moment
- my_elide="Bcc"
- test -n "$opt_from" &&
- my_elide="${my_elide+$my_elide\|}From" && eval echo From: $opt_from
- test -n "$my_destination" &&
- my_elide="${my_elide+$my_elide\|}To" && eval echo To:
$my_destination
- test -n "$opt_carbon_copy" &&
- my_elide="${my_elide+$my_elide\|}Cc" && eval echo CC:
$opt_carbon_copy
- test -n "$opt_subject" &&
- my_elide="${my_elide+$my_elide\|}Subject" && eval echo Subject:
$opt_subject
-
- # Plus any additional headers
- test -n "$opt_headers" && $SED "/^\($my_elide\): */d" "$opt_headers"
- } > "$my_outfile"
-
- :
-}
-
-
-# func_single_content outfile
-# Send the only message part as a single mime mail part.
-func_single_content ()
-{
- $opt_debug
-
- my_outfile="$1"
-
- $opt_dry_run || cat >> "$my_outfile" <<EOF
-Content-Type: $opt_mime_type_1;
-Content-Transfer-Encoding: 7bit
-
-`cat $opt_filename_1`
-EOF
-}
-
-
-# func_multipart_content outfile
-# Send the various message parts to OUTFILE as a multipart mime mail.
-func_multipart_content ()
-{
- $opt_debug
-
- my_outfile="$1"
- boundary="boundary-${HOST}-$$-`date | tr ' :' -`"
- $opt_dry_run || {
- cat <<EOF >> "$my_outfile"
-Content-Type: multipart/mixed;
- boundary="$boundary"
-
-This is a multimedia message in MIME format. If you are reading
-this prefix, your mail reader does not understand MIME. You may
-wish to look into upgrading to a mime-aware mail reader.
-EOF
- i=0
- while test $i -lt $opt_filename_num
- do
- i=`expr 1 + $i`
- eval file=\"\$opt_filename_$i\"
- name=`echo "$file" | $SED $basename`
- {
- echo ""
- echo "--$boundary"
- if test $i -gt 1; then
- eval echo \"Content-Type: \$opt_mime_type_$i\;\"
- echo " name=\"$name\""
- else
- eval echo \"Content-Type: \$opt_mime_type_$i\"
- fi
- echo "Content-Transfer-Encoding: 7bit"
- echo ""
- cat "$file"
- } >> "$my_outfile"
- done
- {
- echo ""
- echo "--${boundary}--"
- echo ""
- } >> "$my_outfile"
- }
-
- :
-}
-
-
-# func_sendmail infile destination [from]
-# Send the message in INFILE to the space delimited list of destination
-# addresses in DESTINATION. If FROM is given, it is the address the
-# mail purports to be from.
-# BEWARE: Many MTAs will refuse mail where FROM does not match the actual
-# sending domain.
-func_sendmail ()
-{
- $opt_debug
-
- my_infile="$1"
- my_destination="$2"
- my_from="$3"
-
- $opt_dry_run && my_infile=/dev/null
-
- from_name=`eval echo "X$my_from" | $Xsed -e 's, *<.*> *$,,'`
- from_addr=`eval echo "X$my_from" | $Xsed -e "$sed_mail_address"`
-
- save_PATH="$PATH"
- PATH="/usr/lib:/usr/sbin:$PATH"
-
- $opt_dry_run || {
- save_IFS="$IFS"
- IFS=':'
- for try_sendmail_dir in $PATH; do
- IFS="$save_IFS"
- PATH="$save_PATH"
- if test -x "$try_sendmail_dir/$SENDMAIL"; then
- SENDMAIL="$try_sendmail_dir/$SENDMAIL"
- break
- fi
- done
- IFS="$save_IFS"
- PATH="$save_PATH"
- test -x "$SENDMAIL" || func_fatal_error "sendmail executable not found"
- }
-
- func_verbose "Delivering mail, please wait..."
- if test -n "$from_name"; then
- $SENDMAIL -F "$from_name" -f "$from_addr" $my_destination <
"$my_infile"
- elif test -n "$from_addr"; then
- $SENDMAIL -f "$from_addr" $my_destination < "$my_infile"
- else
- $SENDMAIL $my_destination < "$my_infile"
- fi
- if test $? -eq 0; then
- func_verbose "...succeeded."
- $opt_dry_run || $RM $my_infile
- else
- func_fatal_error "Mail delivery failed, draft mail is in $my_infile"
- fi
-}
-
-
-# func_extract_email_from_header re_header headerfile
-func_extract_email ()
-{
- $opt_debug
-
- my_re_header="$1"
- my_headerfile="$2"
- $as_unset func_extract_email_result
-
- save_IFS="$IFS"
- IFS='
-'
- for to in : `grep "$my_re_header" "$my_headerfile" 2>/dev/null`; do
- IFS="$save_IFS"
- test "X$to" = X: && continue
-
- line=`echo "$to" | $SED "s,$my_re_header,,"`
-
- IFS=,
- for addr in $line; do
- IFS="$save_IFS"
- func_quote_for_eval "$addr"
- to_addr=`echo "$func_quote_for_eval_result" | $SED
"$sed_mail_address"`
- test -n "$to_addr" || to_addr="$func_quote_for_eval_result"
-
func_extract_email_result="${func_extract_email_result+$func_extract_email_result
}$to_addr"
- done
- done
- IFS="$save_IFS"
-}
-
-## ----- ##
-## main. ##
-## ----- ##
-
-{
- tmp_dir="`func_mktempdir`"
- headers="$tmp_dir/headers"
- fname="$tmp_dir/mail"
-
- trap '$RM -r "$tmp_dir"; exit $EXIT_FAILURE' 1 2 15
-
- # Generate a comma separated list of destination addresses for the
- # mail headers:
- $as_unset destination
- for to in : ${1+"$@"}
- do
- test "X$to" = X: && continue
-
- func_quote_for_eval "$to"
- destination="${destination+$destination, }$func_quote_for_eval_result"
- done
- func_headers "$fname" "$destination"
-
- if test $opt_filename_num -gt 1; then
- func_multipart_content "$fname"
- else
- func_single_content "$fname"
- fi
-
- # Generate a list of destination addresses for sendmail:
- if test -z "$opt_output_file"; then
- $as_unset destination
- for to in : ${1+"$@"}
- do
- test "X$to" = X: && continue
-
- func_quote_for_eval "$to"
-
- to_addr=`echo "$func_quote_for_eval_result" | $SED
"$sed_mail_address"`
- test -n "$to_addr" || to_addr="$func_quote_for_eval_result"
- destination="${destination+$destination }$to_addr"
- done
- func_extract_email '^To: *' "$opt_headers"
- destination="${destination+$destination }$func_extract_email_result"
- func_extract_email '^Cc: *' "$opt_headers"
- destination="${destination+$destination }$func_extract_email_result"
- func_extract_email '^Bcc: *' "$opt_headers"
- destination="${destination+$destination }$func_extract_email_result"
-
- test -n "$opt_from" || {
- func_extract_email '^From: *' "$opt_headers"
- opt_from="$func_extract_email_result"
- }
-
- func_sendmail "$fname" "$destination" "$opt_from"
- else
- mv $fname $opt_output_file || exit $EXIT_FAILURE
- fi
-
- $RM -r "$tmp_dir"
-}
-
-exit $EXIT_SUCCESS
-
-# Local Variables:
-# mode:shell-script
-# sh-indentation:2
-# End:
-]])
-
--
1.7.2.2
- [PATCH] Remove announce-gen.m4sh and mailnotify.m4sh.,
Gary V. Vaughan <=