From mboxrd@z Thu Jan 1 00:00:00 1970 Path: news.gmane.org!not-for-mail From: Paul Eggert Newsgroups: gmane.emacs.bugs Subject: bug#19113: Generate a ChangeLog file from commit logs Date: Sun, 11 Jan 2015 23:38:13 -0800 Organization: UCLA Computer Science Department Message-ID: <54B379E5.8000609@cs.ucla.edu> References: <546D2E75.6090701@cs.ucla.edu> NNTP-Posting-Host: plane.gmane.org Mime-Version: 1.0 Content-Type: multipart/mixed; boundary="------------030803080100020902000203" X-Trace: ger.gmane.org 1421048370 17453 80.91.229.3 (12 Jan 2015 07:39:30 GMT) X-Complaints-To: usenet@ger.gmane.org NNTP-Posting-Date: Mon, 12 Jan 2015 07:39:30 +0000 (UTC) To: 19113@debbugs.gnu.org Original-X-From: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Mon Jan 12 08:39:23 2015 Return-path: Envelope-to: geb-bug-gnu-emacs@m.gmane.org Original-Received: from lists.gnu.org ([208.118.235.17]) by plane.gmane.org with esmtp (Exim 4.69) (envelope-from ) id 1YAZar-0000l2-QB for geb-bug-gnu-emacs@m.gmane.org; Mon, 12 Jan 2015 08:39:22 +0100 Original-Received: from localhost ([::1]:60711 helo=lists.gnu.org) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YAZar-0003ZS-6u for geb-bug-gnu-emacs@m.gmane.org; Mon, 12 Jan 2015 02:39:21 -0500 Original-Received: from eggs.gnu.org ([2001:4830:134:3::10]:58796) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YAZah-0003ZL-1Y for bug-gnu-emacs@gnu.org; Mon, 12 Jan 2015 02:39:17 -0500 Original-Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1YAZaa-0002Su-Mn for bug-gnu-emacs@gnu.org; Mon, 12 Jan 2015 02:39:10 -0500 Original-Received: from debbugs.gnu.org ([140.186.70.43]:45147) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1YAZaa-0002Sq-DJ for bug-gnu-emacs@gnu.org; Mon, 12 Jan 2015 02:39:04 -0500 Original-Received: from Debian-debbugs by debbugs.gnu.org with local (Exim 4.80) (envelope-from ) id 1YAZaZ-0002v5-K3 for bug-gnu-emacs@gnu.org; Mon, 12 Jan 2015 02:39:04 -0500 X-Loop: help-debbugs@gnu.org In-Reply-To: <546D2E75.6090701@cs.ucla.edu> Resent-From: Paul Eggert Original-Sender: "Debbugs-submit" Resent-CC: bug-gnu-emacs@gnu.org Resent-Date: Mon, 12 Jan 2015 07:39:02 +0000 Resent-Message-ID: Resent-Sender: help-debbugs@gnu.org X-GNU-PR-Message: followup 19113 X-GNU-PR-Package: emacs X-GNU-PR-Keywords: patch Original-Received: via spool by 19113-submit@debbugs.gnu.org id=B19113.142104831711132 (code B ref 19113); Mon, 12 Jan 2015 07:39:02 +0000 Original-Received: (at 19113) by debbugs.gnu.org; 12 Jan 2015 07:38:37 +0000 Original-Received: from localhost ([127.0.0.1]:54008 helo=debbugs.gnu.org) by debbugs.gnu.org with esmtp (Exim 4.80) (envelope-from ) id 1YAZa3-0002tF-Sb for submit@debbugs.gnu.org; Mon, 12 Jan 2015 02:38:36 -0500 Original-Received: from smtp.cs.ucla.edu ([131.179.128.62]:41638) by debbugs.gnu.org with esmtp (Exim 4.80) (envelope-from ) id 1YAZZv-0002sO-1e for 19113@debbugs.gnu.org; Mon, 12 Jan 2015 02:38:28 -0500 Original-Received: from localhost (localhost.localdomain [127.0.0.1]) by smtp.cs.ucla.edu (Postfix) with ESMTP id B497FA60050 for <19113@debbugs.gnu.org>; Sun, 11 Jan 2015 23:38:16 -0800 (PST) X-Virus-Scanned: amavisd-new at smtp.cs.ucla.edu Original-Received: from smtp.cs.ucla.edu ([127.0.0.1]) by localhost (smtp.cs.ucla.edu [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id MSRshNU5G7Uz for <19113@debbugs.gnu.org>; Sun, 11 Jan 2015 23:38:13 -0800 (PST) Original-Received: from [192.168.1.9] (pool-173-55-11-52.lsanca.fios.verizon.net [173.55.11.52]) by smtp.cs.ucla.edu (Postfix) with ESMTPSA id CA1A7A6000B for <19113@debbugs.gnu.org>; Sun, 11 Jan 2015 23:38:13 -0800 (PST) User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:31.0) Gecko/20100101 Thunderbird/31.3.0 X-BeenThere: debbugs-submit@debbugs.gnu.org X-Mailman-Version: 2.1.15 Precedence: list X-detected-operating-system: by eggs.gnu.org: GNU/Linux 3.x X-Received-From: 140.186.70.43 X-BeenThere: bug-gnu-emacs@gnu.org List-Id: "Bug reports for GNU Emacs, the Swiss army knife of text editors" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Original-Sender: bug-gnu-emacs-bounces+geb-bug-gnu-emacs=m.gmane.org@gnu.org Xref: news.gmane.org gmane.emacs.bugs:98252 Archived-At: This is a multi-part message in MIME format. --------------030803080100020902000203 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Attached is a proposed announcement for installing the patch (currently it suggests a changeover date of January 21, but obviously that's adjustable), along with updated copies of the rename patch (which should be applied to both emacs-24 and master branches), a followup patch for the emacs-24 branch, and a followup patch for the master branch. This all tries to address some (though not all) the points raised. --------------030803080100020902000203 Content-Type: text/plain; charset=UTF-8; name="announcement.txt" Content-Transfer-Encoding: base64 Content-Disposition: attachment; filename="announcement.txt" T24gSmFudWFyeSAyMSB3ZSBwbGFuIHRvIGNoYW5nZSB0aGUgcHJvY2VkdXJlIGZvciBjb21t aXR0aW5nIGNoYW5nZXMgdG8KdGhlIEVtYWNzIGdpdCByZXBvc2l0b3J5LCBzbyB0aGF0IHRo ZSBDaGFuZ2VMb2cgZmlsZSBpbiB0aGUgRW1hY3MKZGlzdHJpYnV0aW9uIGlzIGdlbmVyYXRl ZCBhdXRvbWF0aWNhbGx5IGZyb20gZ2l0IGNvbW1pdCBtZXNzYWdlcywKaW5zdGVhZCBvZiBi ZWluZyBtYWludGFpbmVkIG1hbnVhbGx5IGFzIGEgbmVhci1jb3B5IG9mIHRoZSBjb21taXQK bWVzc2FnZXMuCgpCZWNhdXNlIHRoZSBDaGFuZ2VMb2cgZmlsZSB3aWxsIG5vIGxvbmdlciBi ZSBmaXhlZCB1cCBieSBoYW5kIGFmdGVyCmNoYW5nZXMgYXJlIGluc3RhbGxlZCwgaXQgd2ls bCBiZSBtb3JlIGltcG9ydGFudCB0byB3cml0ZSBnb29kIGNvbW1pdAptZXNzYWdlcy4gIFRo ZSBzdWdnZXN0ZWQgZm9ybWF0IGlzOgoKICAqIFRoZSBmaXJzdCBsaW5lIHNob3VsZCBiZSBh IGJyaWVmIHN1bW1hcnkgd2l0aG91dCB0cmFpbGluZyBwZXJpb2QuCgogICogVGhlIHNlY29u ZCBsaW5lIHNob3VsZCBiZSBlbXB0eS4KCiAgKiBBbnkgZ2VuZXJhbCBleHBsYW5hdG9yeSB0 ZXh0IHNob3VsZCBjb21lIG5leHQuCgogICogRmluYWxseSwgdGhlIENoYW5nZUxvZyBlbnRy aWVzIHRoZW1zZWx2ZXMgc2hvdWxkIGFwcGVhciwgaW4gdGhlCiAgICBmb3JtYXQgc3BlY2lm aWVkIGJ5IHRoZSBHTlUgY29kaW5nIHN0YW5kYXJkcy4KCiAgKiBBcHBlbmQgYSAiRml4ZXM6 IGJ1ZyNOTk5OIiBsaW5lIGlmIHRoZSBjaGFuZ2UgZml4ZXMgYSBidWcuCgpMaW5lcyBzaG91 bGQgaG9sZCBhdCBtb3N0IDc4IGNoYXJhY3RlcnMuICBIZXJlIGlzIGFuIGV4YW1wbGUgY29t bWl0Cm1lc3NhZ2U6CgoJRGVhY3RpdmF0ZSBzaGlmdGVkIHJlZ2lvbgoKCURvIG5vdCBzaWxl bnRseSBleHRlbmQgYSByZWdpb24gdGhhdCBpcyBub3QgaGlnaGxpZ2h0ZWQ7Cgl0aGlzIGNh biBoYXBwZW4gYWZ0ZXIgYSBzaGlmdC4KCSogbGlzcC93aW5kb3cuZWwgKGhhbmRsZS1zZWxl Y3Qtd2luZG93KToKCSogc3JjL2ZyYW1lLmMgKEZoYW5kbGVfc3dpdGNoX2ZyYW1lLCBGc2Vs ZWN0ZWRfZnJhbWUpOgoJRGVhY3RpdmF0ZSB0aGUgbWFyay4KCUZpeGVzOiBidWcjMTkwMDMK CihUaGUgYWN0dWFsIGNvbW1pdCBtZXNzYWdlIHNob3VsZCBub3QgYmUgaW5kZW50ZWQuKQoK LSBJZiB5b3UgdXNlIEVtYWNzIFZDLCBvbmUgd2F5IHRvIGZvcm1hdCBDaGFuZ2VMb2cgZW50 cmllcyBpcyB0byBjcmVhdGUKICBhIHRvcC1sZXZlbCBDaGFuZ2VMb2cgZmlsZSwgYW5kIHVw ZGF0ZSBpdCB3aXRoICdDLXggNCBhJyBmaWxlIGFzCiAgdXN1YWwuICBEbyBub3QgcmVnaXN0 ZXIgdGhlIENoYW5nZUxvZyBmaWxlIHVuZGVyIGdpdDsgaW5zdGVhZCwgdXNlCiAgJ0MtYyBD LWEnIHRvIGluc2VydCBpdHMgY29udGVudHMgaW50byBpbnRvIHlvdXIgKnZjLWxvZyogYnVm ZmVyLgoKLSBBbHRlcm5hdGl2ZWx5LCB5b3UgY2FuIHVzZSB0aGUgR05VIGNvbW1hbmQgdmMt ZHdpbSAoaWYgaW5zdGFsbGVkKQogIHRvIG1haW50YWluIGNvbW1pdCBtZXNzYWdlcyBpbiBD aGFuZ2VMb2cgZm9ybWF0LiAgV2hlbiB5b3UgY3JlYXRlIGEKICBzb3VyY2UgZGlyZWN0b3J5 IEZPTywgcnVuIHRoZSBzaGVsbCBjb21tYW5kICdjZCBGT087CiAgZ2l0LWNoYW5nZWxvZy1z eW1saW5rLWluaXQnIHRvIGNyZWF0ZSBhIHN5bWJvbGljIGxpbmsgZnJvbSBDaGFuZ2VMb2cK ICB0byAuZ2l0L2MvQ2hhbmdlTG9nLiAgRWRpdCB0aGlzIENoYW5nZUxvZyB2aWEgaXRzIHN5 bWxpbmsgd2l0aCBFbWFjcwogIGNvbW1hbmRzIGxpa2UgJ0MteCA0IGEnLCBhbmQgY29tbWl0 IHRoZSBjaGFuZ2UgdXNpbmcgdGhlIHNoZWxsCiAgY29tbWFuZCAnY2QgRk9POyB2Yy1kd2lt Jy4K --------------030803080100020902000203 Content-Type: text/x-patch; name="rename.patch" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="rename.patch" >From 5a3b51993515fd3a22f23138369c8ebdb4e81664 Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Sun, 11 Jan 2015 22:38:14 -0800 Subject: [PATCH 1/2] Rename ChangeLogs for gitlog-to-changelog This patch was implemented via the following shell commands: find * -name ChangeLog | sed 's,.*,git mv & &.1, s, lisp/ChangeLog\.1$, lisp/ChangeLog.17, s, lisp/erc/ChangeLog\.1$, lisp/erc/ChangeLog.09, s, lisp/gnus/ChangeLog\.1$, lisp/gnus/ChangeLog.3, s, lisp/mh-e/ChangeLog\.1$, lisp/mh-e/ChangeLog.2, s, src/ChangeLog\.1$, src/ChangeLog.13,' | sh git commit -am"[this commit message]" --- [body of patch elided in the interests of brevity] --------------030803080100020902000203 Content-Type: text/x-patch; name="changelog-emacs-24.patch" Content-Transfer-Encoding: 8bit Content-Disposition: attachment; filename="changelog-emacs-24.patch" >From 6d589bea66874973e393f107d16f9e306e94b6af Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Sun, 11 Jan 2015 22:37:08 -0800 Subject: [PATCH] Generate a ChangeLog file from commit logs Instead of having a ChangeLog file or files in the repository, generate the ChangeLog file automatically from the git commit logs, as part of the process of making a distribution. * .gitignore: Add ChangeLog. * Makefile.in (gen_origin): New macro. (gen-ChangeLog): New rule. * admin/admin.el (make-manuals-dist--1): Don't treat ChangeLog specially. * admin/make-tarball.txt, admin/notes/bugtracker: * lisp/emacs-lisp/authors.el: Add a FIXME comment. * admin/merge-gnulib (GNULIB_MODULES): Add gitlog-to-changelog. * admin/notes/repo: Add note about vc-dwim. * admin/admin.el (add-release-logs, make-manuals-dist--1): * build-aux/gitlog-to-changelog: New file, from Gnulib. * build-aux/gitlog-to-emacslog: New file. * lisp/calendar/icalendar.el, lisp/gnus/deuglify.el: * lisp/emacs-lisp/gulp.el, lwlib/README, make-dist: Adjust to renamed old ChangeLog files. * build-aux/git-hooks/pre-commit: Disallow ChangeLog commits. * etc/CONTRIBUTE: Adjust suggested procedures accordingly. * make-dist: Use 'make gen-ChangeLog' to build top-level ChangeLog in the distribution. Distribute gitlog-to-changelog. Fixes: bug#19113 --- .gitignore | 1 + Makefile.in | 8 + admin/admin.el | 9 +- admin/make-tarball.txt | 4 + admin/merge-gnulib | 2 +- admin/notes/bugtracker | 3 +- admin/notes/repo | 12 +- build-aux/git-hooks/pre-commit | 18 +- build-aux/gitlog-to-changelog | 437 +++++++++++++++++++++++++++++++++++++++++ build-aux/gitlog-to-emacslog | 49 +++++ etc/CONTRIBUTE | 65 +++--- lisp/calendar/icalendar.el | 4 +- lisp/emacs-lisp/authors.el | 5 +- lisp/emacs-lisp/gulp.el | 2 +- lisp/gnus/deuglify.el | 2 +- lwlib/README | 2 +- make-dist | 28 ++- 17 files changed, 595 insertions(+), 56 deletions(-) create mode 100755 build-aux/gitlog-to-changelog create mode 100755 build-aux/gitlog-to-emacslog diff --git a/.gitignore b/.gitignore index d326a35..ff57e6f 100644 --- a/.gitignore +++ b/.gitignore @@ -233,6 +233,7 @@ info/dir *~ .#* \#*\# +ChangeLog [0-9]*.patch # Built by 'make install'. diff --git a/Makefile.in b/Makefile.in index 4987cf6..9dd0580 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1100,6 +1100,14 @@ bootstrap: bootstrap-clean FRC $(MAKE) $(MFLAGS) MAKEFILE_NAME=force-Makefile force-Makefile $(MAKE) $(MFLAGS) info all +# The first revision to appear in the generated ChangeLog. +gen_origin = 149749a1daea874283f83a882fb2e679d1417783 +# Convert git commit log to ChangeLog file. make-dist uses this. +.PHONY: gen-ChangeLog +gen-ChangeLog: + $(AM_V_GEN)distprefix=$(distprefix) srcprefix=$(srcdir)/ \ + $(srcdir)/build-aux/gitlog-to-emacslog $(gen_origin) + .PHONY: check-declare check-declare: diff --git a/admin/admin.el b/admin/admin.el index fcdb6cb..c273be4 100644 --- a/admin/admin.el +++ b/admin/admin.el @@ -28,10 +28,9 @@ (defvar add-log-time-format) ; in add-log -;; Does this information need to be in every ChangeLog, as opposed to -;; just the top-level one? Only if you allow changes the same -;; day as the release. -;; http://lists.gnu.org/archive/html/emacs-devel/2013-03/msg00161.html +;; FIXME: Update this in the light of the fact that there's only +;; one ChangeLog file now, at the top level, and it's generated from +;; commit logs by 'make-dist'. (defun add-release-logs (root version &optional date) "Add \"Version VERSION released.\" change log entries in ROOT. Root must be the root of an Emacs source tree. @@ -650,7 +649,7 @@ style=\"text-align:left\">") (copy-file "../doc/misc/texinfo.tex" stem) (or (equal type "emacs") (copy-file "../doc/emacs/emacsver.texi" stem)) (dolist (file (directory-files (format "../doc/%s" type) t)) - (if (or (string-match-p "\\(\\.texi\\'\\|/ChangeLog\\|/README\\'\\)" file) + (if (or (string-match-p "\\(\\.texi\\'\\|/README\\'\\)" file) (and (equal type "lispintro") (string-match-p "\\.\\(eps\\|pdf\\)\\'" file))) (copy-file file stem))) diff --git a/admin/make-tarball.txt b/admin/make-tarball.txt index 9603c61..c080014 100644 --- a/admin/make-tarball.txt +++ b/admin/make-tarball.txt @@ -2,6 +2,10 @@ Instructions to create pretest or release tarballs. -*- coding: utf-8 -*- -- originally written by Gerd Moellmann, amended by Francesco Potortì with the initial help of Eli Zaretskii +FIXME: There is now just one ChangeLog file, at the top level, +generated automatically from commit logs by 'make-dist'. The +procedure below needs to be updated accordingly. + Steps to take before starting on the first pretest in any release sequence: diff --git a/admin/merge-gnulib b/admin/merge-gnulib index cfc1a34..09cf629 100755 --- a/admin/merge-gnulib +++ b/admin/merge-gnulib @@ -31,7 +31,7 @@ GNULIB_MODULES=' crypto/md5 crypto/sha1 crypto/sha256 crypto/sha512 dtoastr dtotimespec dup2 environ execinfo faccessat fcntl fcntl-h fdatasync fdopendir filemode fstatat fsync - getloadavg getopt-gnu gettime gettimeofday + getloadavg getopt-gnu gettime gettimeofday gitlog-to-changelog intprops largefile lstat manywarnings memrchr mkostemp mktime pipe2 pselect pthread_sigmask putenv qacl readlink readlinkat diff --git a/admin/notes/bugtracker b/admin/notes/bugtracker index fd7bd08..9d03798 100644 --- a/admin/notes/bugtracker +++ b/admin/notes/bugtracker @@ -481,7 +481,8 @@ can see exactly what the fix was. *** bug-reference-mode Activate `bug-reference-mode' in ChangeLogs to get clickable links to -the bug web-pages. +the bug web-pages. FIXME: This may need to be updated in the light of +the new policy of just one ChangeLog, at the top level. *** Debian stuff diff --git a/admin/notes/repo b/admin/notes/repo index 46a9e08..a9da8fc 100644 --- a/admin/notes/repo +++ b/admin/notes/repo @@ -37,6 +37,15 @@ NEWS, MAINTAINERS, and FOR-RELEASE, or to indicate regeneration of files such as 'configure'. "There is no need" means you don't have to, but you can if you want to. +** Using vc-dwim to maintain commit messages + +You can use vc-dwim to maintain commit messages in ChangeLog format. +When you create a source directory FOO, run the shell command 'cd FOO; +git-changelog-symlink-init' to create a symbolic link from ChangeLog +to .git/c/ChangeLog. Edit this ChangeLog via its symlink with Emacs +commands like 'C-x 4 a', and commit the change using the shell command +'cd FOO; vc-dwim'. Type 'vc-dwim --help' for more info. + * Commit to the right branch Development normally takes places on the trunk. @@ -132,7 +141,8 @@ http://lists.gnu.org/archive/html/emacs-devel/2010-05/msg00262.html * How to merge changes from emacs-24 to trunk -[The section on git merge procedure has not yet been written] +[The section on git merge procedure has not yet been written. +Among other things, the ChangeLog file is now automatically generated.] Inspect the change log entries (e.g. in case too many entries have been included or whitespace between entries needs fixing). If someone made diff --git a/build-aux/git-hooks/pre-commit b/build-aux/git-hooks/pre-commit index d050c40..8bce1f5 100755 --- a/build-aux/git-hooks/pre-commit +++ b/build-aux/git-hooks/pre-commit @@ -34,13 +34,15 @@ if test "$nbadchars" -ne 0; then exit 1 fi -new_names=`$git_diff HEAD` || exit -case " -$new_names" in - */-* | *' -'-*) - echo "File name component begins with '-'." - exit 1;; -esac +for new_name in `$git_diff HEAD`; do + case $new_name in + -* | */-*) + echo "$new_name: File name component begins with '-'." + exit 1;; + ChangeLog | */ChangeLog) + echo "$new_name: Please use git commit messages, not ChangeLog files." + exit 1;; + esac +done exec git diff-index --check --cached HEAD -- diff --git a/build-aux/gitlog-to-changelog b/build-aux/gitlog-to-changelog new file mode 100755 index 0000000..190f7b5 --- /dev/null +++ b/build-aux/gitlog-to-changelog @@ -0,0 +1,437 @@ +eval '(exit $?0)' && eval 'exec perl -wS "$0" ${1+"$@"}' + & eval 'exec perl -wS "$0" $argv:q' + if 0; +# Convert git log output to ChangeLog format. + +my $VERSION = '2014-11-20 17:25'; # UTC +# The definition above must lie within the first 8 lines in order +# for the Emacs time-stamp write hook (at end) to update it. +# If you change this file with Emacs, please let the write hook +# do its job. Otherwise, update this string manually. + +# Copyright (C) 2008-2014 Free Software Foundation, Inc. + +# This program 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 3 of the License, or +# (at your option) any later version. + +# This program 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 this program. If not, see . + +# Written by Jim Meyering + +use strict; +use warnings; +use Getopt::Long; +use POSIX qw(strftime); + +(my $ME = $0) =~ s|.*/||; + +# use File::Coda; # http://meyering.net/code/Coda/ +END { + defined fileno STDOUT or return; + close STDOUT and return; + warn "$ME: failed to close standard output: $!\n"; + $? ||= 1; +} + +sub usage ($) +{ + my ($exit_code) = @_; + my $STREAM = ($exit_code == 0 ? *STDOUT : *STDERR); + if ($exit_code != 0) + { + print $STREAM "Try '$ME --help' for more information.\n"; + } + else + { + print $STREAM < ChangeLog + $ME -- -n 5 foo > last-5-commits-to-branch-foo + +SPECIAL SYNTAX: + +The following types of strings are interpreted specially when they appear +at the beginning of a log message line. They are not copied to the output. + + Copyright-paperwork-exempt: Yes + Append the "(tiny change)" notation to the usual "date name email" + ChangeLog header to mark a change that does not require a copyright + assignment. + Co-authored-by: Joe User + List the specified name and email address on a second + ChangeLog header, denoting a co-author. + Signed-off-by: Joe User + These lines are simply elided. + +In a FILE specified via --amend, comment lines (starting with "#") are ignored. +FILE must consist of pairs where SHA is a 40-byte SHA1 (alone on +a line) referring to a commit in the current project, and CODE refers to one +or more consecutive lines of Perl code. Pairs must be separated by one or +more blank line. + +Here is sample input for use with --amend=FILE, from coreutils: + +3a169f4c5d9159283548178668d2fae6fced3030 +# fix typo in title: +s/all tile types/all file types/ + +1379ed974f1fa39b12e2ffab18b3f7a607082202 +# Due to a bug in vc-dwim, I mis-attributed a patch by Paul to myself. +# Change the author to be Paul. Note the escaped "@": +s,Jim .*>,Paul Eggert , + +EOF + } + exit $exit_code; +} + +# If the string $S is a well-behaved file name, simply return it. +# If it contains white space, quotes, etc., quote it, and return the new string. +sub shell_quote($) +{ + my ($s) = @_; + if ($s =~ m![^\w+/.,-]!) + { + # Convert each single quote to '\'' + $s =~ s/\'/\'\\\'\'/g; + # Then single quote the string. + $s = "'$s'"; + } + return $s; +} + +sub quoted_cmd(@) +{ + return join (' ', map {shell_quote $_} @_); +} + +# Parse file F. +# Comment lines (starting with "#") are ignored. +# F must consist of pairs where SHA is a 40-byte SHA1 +# (alone on a line) referring to a commit in the current project, and +# CODE refers to one or more consecutive lines of Perl code. +# Pairs must be separated by one or more blank line. +sub parse_amend_file($) +{ + my ($f) = @_; + + open F, '<', $f + or die "$ME: $f: failed to open for reading: $!\n"; + + my $fail; + my $h = {}; + my $in_code = 0; + my $sha; + while (defined (my $line = )) + { + $line =~ /^\#/ + and next; + chomp $line; + $line eq '' + and $in_code = 0, next; + + if (!$in_code) + { + $line =~ /^([0-9a-fA-F]{40})$/ + or (warn "$ME: $f:$.: invalid line; expected an SHA1\n"), + $fail = 1, next; + $sha = lc $1; + $in_code = 1; + exists $h->{$sha} + and (warn "$ME: $f:$.: duplicate SHA1\n"), + $fail = 1, next; + } + else + { + $h->{$sha} ||= ''; + $h->{$sha} .= "$line\n"; + } + } + close F; + + $fail + and exit 1; + + return $h; +} + +# git_dir_option $SRCDIR +# +# From $SRCDIR, the --git-dir option to pass to git (none if $SRCDIR +# is undef). Return as a list (0 or 1 element). +sub git_dir_option($) +{ + my ($srcdir) = @_; + my @res = (); + if (defined $srcdir) + { + my $qdir = shell_quote $srcdir; + my $cmd = "cd $qdir && git rev-parse --show-toplevel"; + my $qcmd = shell_quote $cmd; + my $git_dir = qx($cmd); + defined $git_dir + or die "$ME: cannot run $qcmd: $!\n"; + $? == 0 + or die "$ME: $qcmd had unexpected exit code or signal ($?)\n"; + chomp $git_dir; + push @res, "--git-dir=$git_dir/.git"; + } + @res; +} + +{ + my $since_date; + my $until_date; + my $format_string = '%s%n%b%n'; + my $amend_file; + my $append_dot = 0; + my $cluster = 1; + my $strip_tab = 0; + my $strip_cherry_pick = 0; + my $srcdir; + GetOptions + ( + help => sub { usage 0 }, + version => sub { print "$ME version $VERSION\n"; exit }, + 'since=s' => \$since_date, + 'until=s' => \$until_date, + 'format=s' => \$format_string, + 'amend=s' => \$amend_file, + 'append-dot' => \$append_dot, + 'cluster!' => \$cluster, + 'strip-tab' => \$strip_tab, + 'strip-cherry-pick' => \$strip_cherry_pick, + 'srcdir=s' => \$srcdir, + ) or usage 1; + + defined $since_date + and unshift @ARGV, "--since=$since_date"; + defined $until_date + and unshift @ARGV, "--until=$until_date"; + + # This is a hash that maps an SHA1 to perl code (i.e., s/old/new/) + # that makes a correction in the log or attribution of that commit. + my $amend_code = defined $amend_file ? parse_amend_file $amend_file : {}; + + my @cmd = ('git', + git_dir_option $srcdir, + qw(log --log-size), + '--pretty=format:%H:%ct %an <%ae>%n%n'.$format_string, @ARGV); + open PIPE, '-|', @cmd + or die ("$ME: failed to run '". quoted_cmd (@cmd) ."': $!\n" + . "(Is your Git too old? Version 1.5.1 or later is required.)\n"); + + my $prev_multi_paragraph; + my $prev_date_line = ''; + my @prev_coauthors = (); + while (1) + { + defined (my $in = ) + or last; + $in =~ /^log size (\d+)$/ + or die "$ME:$.: Invalid line (expected log size):\n$in"; + my $log_nbytes = $1; + + my $log; + my $n_read = read PIPE, $log, $log_nbytes; + $n_read == $log_nbytes + or die "$ME:$.: unexpected EOF\n"; + + # Extract leading hash. + my ($sha, $rest) = split ':', $log, 2; + defined $sha + or die "$ME:$.: malformed log entry\n"; + $sha =~ /^[0-9a-fA-F]{40}$/ + or die "$ME:$.: invalid SHA1: $sha\n"; + + # If this commit's log requires any transformation, do it now. + my $code = $amend_code->{$sha}; + if (defined $code) + { + eval 'use Safe'; + my $s = new Safe; + # Put the unpreprocessed entry into "$_". + $_ = $rest; + + # Let $code operate on it, safely. + my $r = $s->reval("$code") + or die "$ME:$.:$sha: failed to eval \"$code\":\n$@\n"; + + # Note that we've used this entry. + delete $amend_code->{$sha}; + + # Update $rest upon success. + $rest = $_; + } + + # Remove lines inserted by "git cherry-pick". + if ($strip_cherry_pick) + { + $rest =~ s/^\s*Conflicts:\n.*//sm; + $rest =~ s/^\s*\(cherry picked from commit [\da-f]+\)\n//m; + } + + my @line = split "\n", $rest; + my $author_line = shift @line; + defined $author_line + or die "$ME:$.: unexpected EOF\n"; + $author_line =~ /^(\d+) (.*>)$/ + or die "$ME:$.: Invalid line " + . "(expected date/author/email):\n$author_line\n"; + + # Format 'Copyright-paperwork-exempt: Yes' as a standard ChangeLog + # `(tiny change)' annotation. + my $tiny = (grep (/^Copyright-paperwork-exempt:\s+[Yy]es$/, @line) + ? ' (tiny change)' : ''); + + my $date_line = sprintf "%s %s$tiny\n", + strftime ("%F", localtime ($1)), $2; + + my @coauthors = grep /^Co-authored-by:.*$/, @line; + # Omit meta-data lines we've already interpreted. + @line = grep !/^(?:Signed-off-by:[ ].*>$ + |Co-authored-by:[ ] + |Copyright-paperwork-exempt:[ ] + )/x, @line; + + # Remove leading and trailing blank lines. + if (@line) + { + while ($line[0] =~ /^\s*$/) { shift @line; } + while ($line[$#line] =~ /^\s*$/) { pop @line; } + } + + # Record whether there are two or more paragraphs. + my $multi_paragraph = grep /^\s*$/, @line; + + # Format 'Co-authored-by: A U Thor ' lines in + # standard multi-author ChangeLog format. + for (@coauthors) + { + s/^Co-authored-by:\s*/\t /; + s/\s*/ + or warn "$ME: warning: missing email address for " + . substr ($_, 5) . "\n"; + } + + # If clustering of commit messages has been disabled, if this header + # would be different from the previous date/name/email/coauthors header, + # or if this or the previous entry consists of two or more paragraphs, + # then print the header. + if ( ! $cluster + || $date_line ne $prev_date_line + || "@coauthors" ne "@prev_coauthors" + || $multi_paragraph + || $prev_multi_paragraph) + { + $prev_date_line eq '' + or print "\n"; + print $date_line; + @coauthors + and print join ("\n", @coauthors), "\n"; + } + $prev_date_line = $date_line; + @prev_coauthors = @coauthors; + $prev_multi_paragraph = $multi_paragraph; + + # If there were any lines + if (@line == 0) + { + warn "$ME: warning: empty commit message:\n $date_line\n"; + } + else + { + if ($append_dot) + { + # If the first line of the message has enough room, then + if (length $line[0] < 72) + { + # append a dot if there is no other punctuation or blank + # at the end. + $line[0] =~ /[[:punct:]\s]$/ + or $line[0] .= '.'; + } + } + + # Remove one additional leading TAB from each line. + $strip_tab + and map { s/^\t// } @line; + + # Prefix each non-empty line with a TAB. + @line = map { length $_ ? "\t$_" : '' } @line; + + print "\n", join ("\n", @line), "\n"; + } + + defined ($in = ) + or last; + $in ne "\n" + and die "$ME:$.: unexpected line:\n$in"; + } + + close PIPE + or die "$ME: error closing pipe from " . quoted_cmd (@cmd) . "\n"; + # FIXME-someday: include $PROCESS_STATUS in the diagnostic + + # Complain about any unused entry in the --amend=F specified file. + my $fail = 0; + foreach my $sha (keys %$amend_code) + { + warn "$ME:$amend_file: unused entry: $sha\n"; + $fail = 1; + } + + exit $fail; +} + +# Local Variables: +# mode: perl +# indent-tabs-mode: nil +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "my $VERSION = '" +# time-stamp-format: "%:y-%02m-%02d %02H:%02M" +# time-stamp-time-zone: "UTC" +# time-stamp-end: "'; # UTC" +# End: diff --git a/build-aux/gitlog-to-emacslog b/build-aux/gitlog-to-emacslog new file mode 100755 index 0000000..8ea8112 --- /dev/null +++ b/build-aux/gitlog-to-emacslog @@ -0,0 +1,49 @@ +#!/bin/sh + +# Convert git log output to ChangeLog format for GNU Emacs. + +# Copyright (C) 2014 Free Software Foundation, Inc. + +# This program 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 3 of the License, or +# (at your option) any later version. + +# This program 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 this program. If not, see . + +LC_ALL=C +export LC_ALL + +gen_origin=${1?} +shift + +if test -d ${srcprefix}.git; then + gen_origin_date=`git log --pretty=format:%ci "$gen_origin"^! ` || exit + gen_start_year=`expr "$gen_origin_date" : '\([^-]*\)'` || exit + log_fix="${srcprefix}build-aux/git-log-fix" + test -e "$log_fix" && set -- "$@" --amend="$log_fix" + + ${srcprefix}build-aux/gitlog-to-changelog "$@" $gen_origin^.. \ + > ${distprefix}cl-t || exit + + gen_end_year=`sed 's/-.*//; q' ${distprefix}cl-t` + if test "$gen_start_year" = "$gen_end_year"; then + year_range=$gen_start_year + else + year_range=$gen_start_year-$gen_end_year + fi + + sed "1d + s/Copyright (C) [0-9]*-[0-9]*/Copyright (C) $year_range/ + s/^# // + /http:/q + " Makefile.in >>${distprefix}cl-t && + rm -f ${distprefix}ChangeLog && + mv ${distprefix}cl-t ${distprefix}ChangeLog +fi diff --git a/etc/CONTRIBUTE b/etc/CONTRIBUTE index 92b4c9e..51820c7 100644 --- a/etc/CONTRIBUTE +++ b/etc/CONTRIBUTE @@ -101,6 +101,16 @@ If your patch is not complete and you think it needs more discussion, you might want to send it to emacs-devel@gnu.org instead. If you revise your patch, send it as a followup to the initial topic. +** Do not mix changes. + +If you send several unrelated changes together, we will ask you to +separate them so we can consider each of the changes by itself. + +** Do not make formatting changes. + +Making cosmetic formatting changes (indentation, etc.) makes it harder +to see what you have really changed. + ** Description For bug fixes, a description of the bug and how your patch fixes it. @@ -109,20 +119,37 @@ For new features, a description of the feature and your implementation. ** ChangeLog -A ChangeLog entry as plaintext (separate from the patch). +A ChangeLog entry, which should be separate from the rest of the patch. + +Normally the git commit message should contain the ChangeLog entry, +starting with a single short line explaining the change, then an empty +line, then ChangeLog entries. Append a "Fixes:" line if the commit +fixes a bug numbered at http://debbugs.gnu.org. Here is an indented +example (the actual commit message should not be indented): -See the existing ChangeLog files for format and content. Note that, -unlike some other projects, we do require ChangeLogs also for -documentation, i.e. Texinfo files. + Deactivate shifted region + + Do not silently extend a region that is not highlighted; + this can happen after a shift. + * doc/emacs/mark.texi (Shift Selection): Document the change. + * lisp/window.el (handle-select-window): + * src/frame.c (Fhandle_switch_frame, Fselected_frame): + Deactivate the mark. + Fixes: bug#19003 + +If you don't use git, the ChangeLog entry should be in plaintext and +should be separate from the patch. Ref: "Change Log Concepts" node of the GNU Coding Standards Info -Manual, for how to write good log entries. +Manual, for how to write good log entries. Unlike some other +projects, we require ChangeLog entries also for documentation, i.e., +Texinfo files. -When using git, commit messages should use ChangeLog format, with a -single short line explaining the change, then an empty line, then -unindented ChangeLog entries. (Essentially, a commit message should -be a duplicate of what the patch adds to the ChangeLog files. We are -planning to automate this better, to avoid the duplication.) +If you use Emacs VC, one way to format ChangeLog entries is to create +a top-level ChangeLog file, and update it with 'C-x 4 a' file as +usual. Do not register the ChangeLog file under git; instead, use +'C-c C-a' to insert its contents into into your *vc-log* buffer. +Alternatively, you can use vc-dwim as described in ../admin/repo. ** The patch itself. @@ -131,27 +158,17 @@ up-to-date (e.g. with 'git pull'). You can commit your changes to a private branch and generate a patch from the master version by using git format-patch master -Or you can leave your changes uncommitted and use - git diff With no repository, you can use diff -u OLD NEW +** Please reread your patch before submitting it. + ** Mail format. We prefer to get the patches as plain text, either inline (be careful your mail client does not change line breaks) or as MIME attachments. - -** Please reread your patch before submitting it. - -** Do not mix changes. - -If you send several unrelated changes together, we will ask you to -separate them so we can consider each of the changes by itself. - -** Do not make formatting changes. - -Making cosmetic formatting changes (indentation, etc) makes it harder -to see what you have really changed. +To send a git-format patch inline, you can use + git send-email 0001-FOO.patch * Coding style and conventions. diff --git a/lisp/calendar/icalendar.el b/lisp/calendar/icalendar.el index 638f99f..ce6135e 100644 --- a/lisp/calendar/icalendar.el +++ b/lisp/calendar/icalendar.el @@ -39,7 +39,7 @@ ;;; History: -;; 0.07 onwards: see lisp/ChangeLog +;; 0.07 onwards: see commit logs and ../ChangeLog*. ;; 0.06: (2004-10-06) ;; - Bugfixes regarding icalendar-import-format-*. @@ -1047,7 +1047,7 @@ FExport diary data into iCalendar file: ") (setq header (concat "\nBEGIN:VEVENT\nUID:" (or uid - (icalendar--create-uid entry-full + (icalendar--create-uid entry-full contents))))) (setq result (concat result header contents "\nEND:VEVENT"))) ;; handle errors diff --git a/lisp/emacs-lisp/authors.el b/lisp/emacs-lisp/authors.el index e20ae95..e095be6 100644 --- a/lisp/emacs-lisp/authors.el +++ b/lisp/emacs-lisp/authors.el @@ -27,6 +27,9 @@ ;; Use M-x authors RET to create an *Authors* buffer that can used as ;; or merged with Emacs's AUTHORS file. +;; FIXME: This needs to modernized in the light of current practice, +;; which generates a single top-level ChangeLog file from commit logs. + ;;; Code: (defvar authors-coding-system 'utf-8 @@ -75,7 +78,7 @@ files.") ("Gerd Möllmann" "Gerd Moellmann") ("Hallvard B. Furuseth" "Hallvard B Furuseth" "Hallvard Furuseth") ("Hrvoje Nikšić" "Hrvoje Niksic") - ;; lisp/org/ChangeLog 2010-11-11. + ;; lisp/org/ChangeLog.1 2010-11-11. (nil "aaa bbb") (nil "Code Extracted") ; lisp/newcomment.el's "Author:" header ("Jaeyoun Chung" "Jae-youn Chung" "Jae-you Chung" "Chung Jae-youn") diff --git a/lisp/emacs-lisp/gulp.el b/lisp/emacs-lisp/gulp.el index ccefc09..b26f3f4 100644 --- a/lisp/emacs-lisp/gulp.el +++ b/lisp/emacs-lisp/gulp.el @@ -69,7 +69,7 @@ please send them to me ASAP. Please don't send the whole file. Instead, please send a patch made with `diff -c' that shows precisely the changes you would like me to install. Also please include itemized change log entries for your changes; -please use lisp/ChangeLog as a guide for the style and for what kinds +please use lisp/ChangeLog* as a guide for the style and for what kinds of information to include. Thanks.") diff --git a/lisp/gnus/deuglify.el b/lisp/gnus/deuglify.el index 00d1ee9..92f2c00 100644 --- a/lisp/gnus/deuglify.el +++ b/lisp/gnus/deuglify.el @@ -188,7 +188,7 @@ ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; -;; See ChangeLog for other changes. +;; See commit log or ChangeLog* for other changes. ;; ;; Revision 1.5 2002/01/27 14:39:17 rscholz ;; * New variable `gnus-outlook-deuglify-no-wrap-chars' to inhibit diff --git a/lwlib/README b/lwlib/README index 25c72eb..ed7583d 100644 --- a/lwlib/README +++ b/lwlib/README @@ -4,4 +4,4 @@ library was written by Lucid, Inc and released under the terms of the GPL version 1 (or later). It is not considered part of GNU Emacs. This version of the library differs from the original as described in -the ChangeLog file. +the ChangeLog.1 file. diff --git a/make-dist b/make-dist index df5e505..20e49d1 100755 --- a/make-dist +++ b/make-dist @@ -278,13 +278,20 @@ fi echo "Creating top directory: \`${tempdir}'" mkdir ${tempdir} +if test -d .git; then + echo "Making top-level ChangeLog" + make distprefix=${tempdir}/ gen-ChangeLog +else + echo "No repository, so omitting top-level ChangeLog" +fi + ### We copy in the top-level files before creating the subdirectories in ### hopes that this will make the top-level files appear first in the ### tar file; this means that people can start reading the INSTALL and ### README while the rest of the tar file is still unpacking. Whoopee. echo "Making links to top-level files" ln INSTALL README BUGS ${tempdir} -ln ChangeLog Makefile.in autogen.sh configure configure.ac ${tempdir} +ln ChangeLog.*[0-9] Makefile.in autogen.sh configure configure.ac ${tempdir} ln config.bat make-dist .dir-locals.el ${tempdir} ln aclocal.m4 ${tempdir} @@ -334,7 +341,7 @@ done echo "Making links to \`leim' and its subdirectories" (cd leim ln makefile.w32-in ../${tempdir}/leim - ln ChangeLog README ../${tempdir}/leim + ln ChangeLog.*[0-9] README ../${tempdir}/leim ln CXTERM-DIC/README CXTERM-DIC/*.tit ../${tempdir}/leim/CXTERM-DIC ln SKK-DIC/README SKK-DIC/SKK-JISYO.L ../${tempdir}/leim/SKK-DIC ln MISC-DIC/README MISC-DIC/*.* ../${tempdir}/leim/MISC-DIC @@ -345,6 +352,7 @@ echo "Making links to \`leim' and its subdirectories" echo "Making links to \`build-aux'" (cd build-aux ln compile config.guess config.sub depcomp msys-to-w32 ../${tempdir}/build-aux + ln gitlog-to-changelog ../${tempdir}/build-aux ln install-sh missing move-if-change ../${tempdir}/build-aux ln update-copyright update-subdirs ../${tempdir}/build-aux ln dir_top make-info-dir ../${tempdir}/build-aux) @@ -361,7 +369,7 @@ echo "Making links to \`src'" ln [a-zA-Z]*.[chm] ../${tempdir}/src ln [a-zA-Z]*.in ../${tempdir}/src ln [a-zA-Z]*.mk ../${tempdir}/src - ln README ChangeLog ChangeLog.*[0-9] ../${tempdir}/src + ln README ChangeLog.*[0-9] ../${tempdir}/src ln makefile.w32-in ../${tempdir}/src ln .gdbinit .dbxinit ../${tempdir}/src cd ../${tempdir}/src @@ -383,7 +391,7 @@ echo "Making links to \`lib'" echo "Making links to \`lib-src'" (cd lib-src ln [a-zA-Z]*.[ch] ../${tempdir}/lib-src - ln ChangeLog Makefile.in README testfile ../${tempdir}/lib-src + ln ChangeLog.*[0-9] Makefile.in README testfile ../${tempdir}/lib-src ln grep-changelog rcs2log ../${tempdir}/lib-src ln makefile.w32-in ../${tempdir}/lib-src ln update-game-score.exe.manifest ../${tempdir}/lib-src) @@ -399,7 +407,7 @@ echo "Making links to \`nt'" ln nmake.defs gmake.defs subdirs.el [a-z]*.bat [a-z]*.[ch] ../${tempdir}/nt ln Makefile.in gnulib.mk ../${tempdir}/nt ln mingw-cfg.site epaths.nt INSTALL.OLD ../${tempdir}/nt - ln ChangeLog INSTALL README README.W32 makefile.w32-in ../${tempdir}/nt) + ln ChangeLog.*[0-9] INSTALL README README.W32 makefile.w32-in ../${tempdir}/nt) echo "Making links to \`nt/inc' and its subdirectories" for f in `find nt/inc -type f -name '[a-z]*.h'`; do @@ -413,13 +421,13 @@ echo "Making links to \`nt/icons'" echo "Making links to \`msdos'" (cd msdos - ln ChangeLog INSTALL README emacs.ico emacs.pif ../${tempdir}/msdos + ln ChangeLog.*[0-9] INSTALL README emacs.ico emacs.pif ../${tempdir}/msdos ln depfiles.bat inttypes.h ../${tempdir}/msdos ln is_exec.c sigaction.c mainmake.v2 sed*.inp ../${tempdir}/msdos) echo "Making links to \`nextstep'" (cd nextstep - ln ChangeLog README INSTALL Makefile.in ../${tempdir}/nextstep) + ln ChangeLog.*[0-9] README INSTALL Makefile.in ../${tempdir}/nextstep) echo "Making links to \`nextstep/templates'" (cd nextstep/templates @@ -440,12 +448,12 @@ echo "Making links to \`nextstep/GNUstep/Emacs.base/Resources'" echo "Making links to \`oldXMenu'" (cd oldXMenu ln *.[ch] *.in ../${tempdir}/oldXMenu - ln README ChangeLog ../${tempdir}/oldXMenu) + ln README ChangeLog.*[0-9] ../${tempdir}/oldXMenu) echo "Making links to \`lwlib'" (cd lwlib ln *.[ch] *.in ../${tempdir}/lwlib - ln README ChangeLog ../${tempdir}/lwlib) + ln README ChangeLog.*[0-9] ../${tempdir}/lwlib) ## It is important to distribute admin/ because it contains sources ## for generated lisp/international/uni-*.el files. @@ -504,7 +512,7 @@ echo "Making links to \`doc/lispintro'" echo "Making links to \`doc/man'" (cd doc/man - ln ChangeLog* *.1 ../../${tempdir}/doc/man + ln *.1 ../../${tempdir}/doc/man cd ../../${tempdir}/doc/man) ### It would be nice if they could all be symlinks to top-level copy, but -- 2.1.0 --------------030803080100020902000203 Content-Type: text/x-patch; name="changelog-master.patch" Content-Transfer-Encoding: 8bit Content-Disposition: attachment; filename="changelog-master.patch" >From 071a20671bc7b01565243529f51eb2236a0e7134 Mon Sep 17 00:00:00 2001 From: Paul Eggert Date: Sun, 11 Jan 2015 22:42:09 -0800 Subject: [PATCH] Generate a ChangeLog file from commit logs Instead of having a ChangeLog file or files in the repository, generate the ChangeLog file automatically from the git commit logs, as part of the process of making a distribution. * .gitignore: Add ChangeLog. * CONTRIBUTE: Adjust suggested procedures accordingly. * Makefile.in (gen_origin): New macro. (gen-ChangeLog): New rule. * admin/admin.el (make-manuals-dist--1): Don't treat ChangeLog specially. * admin/make-tarball.txt, admin/notes/bugtracker, admin/notes/repo: * lisp/emacs-lisp/authors.el: Add a FIXME comment. * admin/merge-gnulib (GNULIB_MODULES): Add gitlog-to-changelog. * admin/admin.el (add-release-logs, make-manuals-dist--1): * build-aux/git-hooks/pre-commit: Disallow ChangeLog commits. * build-aux/gitlog-to-changelog: New file, from Gnulib. * build-aux/gitlog-to-emacslog: New file. * lisp/calendar/icalendar.el, lisp/gnus/deuglify.el: * lisp/emacs-lisp/gulp.el, lwlib/README, make-dist: Adjust to renamed old ChangeLog files. * make-dist: Use 'make gen-ChangeLog' to build top-level ChangeLog in the distribution. Distribute gitlog-to-changelog. Fixes: bug#19113 --- .gitignore | 1 + CONTRIBUTE | 57 ++++-- Makefile.in | 8 + admin/admin.el | 9 +- admin/authors.el | 5 +- admin/make-tarball.txt | 4 + admin/merge-gnulib | 2 +- admin/notes/bugtracker | 3 +- admin/notes/repo | 3 +- build-aux/git-hooks/pre-commit | 18 +- build-aux/gitlog-to-changelog | 437 +++++++++++++++++++++++++++++++++++++++++ build-aux/gitlog-to-emacslog | 49 +++++ lisp/calendar/icalendar.el | 2 +- lisp/gnus/deuglify.el | 2 +- lisp/obsolete/gulp.el | 2 +- lwlib/README | 2 +- make-dist | 16 +- 17 files changed, 578 insertions(+), 42 deletions(-) create mode 100755 build-aux/gitlog-to-changelog create mode 100755 build-aux/gitlog-to-emacslog diff --git a/.gitignore b/.gitignore index 9810c1d..67d28653 100644 --- a/.gitignore +++ b/.gitignore @@ -237,6 +237,7 @@ info/dir *~ .#* \#*\# +ChangeLog [0-9]*.patch # Built by 'make install'. diff --git a/CONTRIBUTE b/CONTRIBUTE index 5cf015f..c5e36bd 100644 --- a/CONTRIBUTE +++ b/CONTRIBUTE @@ -27,10 +27,10 @@ advanced information. Alternately, see admin/notes/git-workflow. -If committing changes written by someone else, make the ChangeLog -entry in their name, not yours. git distinguishes between the author -and the committer; use the --author option on the commit command to -specify the actual author; the committer defaults to you. +If committing changes written by someone else, do so in their name, +not yours. git distinguishes between the author and the committer; +use the --author option on the commit command to specify the actual +author; the committer defaults to you. ** commit messages @@ -77,28 +77,29 @@ following modifications: and have a reasonable chance of being read in the future, so it's better that they have good presentation. -- There are multiple ChangeLogs in the emacs source; roughly one per - high-level directory. The ChangeLog entry for a commit belongs in the - lowest ChangeLog that is higher than or at the same level as any file - changed by the commit. - - Use the present tense; describe "what the change does", not "what the change did". -- Preferred form for several entries with the same content: - - * help.el (view-lossage): - * kmacro.el (kmacro-edit-lossage): - * edmacro.el (edit-kbd-macro): Fix docstring, lossage is now 300 keys. - - (Rather than anything involving "ditto" and suchlike.) - - If the commit fixes a bug, add a separate line Fixes: bug#NNNN where NNNN is the bug number. +- Here is an example, showing the preferred form for several entries + with the same content: + + Deactivate shifted region + + Do not silently extend a region that is not highlighted; + this can happen after a shift. + * lisp/window.el (handle-select-window): + * src/frame.c (Fhandle_switch_frame, Fselected_frame): + Deactivate the mark. + Fixes: bug#19003 + + (Rather than anything involving "ditto" and suchlike.) + - In ChangeLog entries, there is no standard or recommended way to identify revisions. @@ -113,6 +114,19 @@ following modifications: of files such as 'configure'. "There is no need" means you don't have to, but you can if you want to. +- If you use Emacs VC, one way to format ChangeLog entries is to create + a top-level ChangeLog file, and update it with 'C-x 4 a' file as + usual. Do not register the ChangeLog file under git; instead, use + 'C-c C-a' to insert its contents into into your *vc-log* buffer. + +- Alternatively, you can use the GNU command vc-dwim (if installed) + to maintain commit messages in ChangeLog format. When you create a + source directory FOO, run the shell command 'cd FOO; + git-changelog-symlink-init' to create a symbolic link from ChangeLog + to .git/c/ChangeLog. Edit this ChangeLog via its symlink with Emacs + commands like 'C-x 4 a', and commit the change using the shell + command 'cd FOO; vc-dwim'. + ** branches Development normally takes places on the trunk. @@ -176,6 +190,15 @@ to the tracker at http://debbugs.gnu.org . You can subscribe to the mailing lists, or see the list archives, by following links from http://savannah.gnu.org/mail/?group=emacs . +To send a git-format patch to the mailing list, which contains the +most recent commit in your private repository, you can use a shell +command like this: + + git format-patch -1 + git send-email 0001-*.patch + +Double-check the patch before sending it. + ** Document your changes. Any change that matters to end-users should have an entry in etc/NEWS. diff --git a/Makefile.in b/Makefile.in index 4cdd293..1c45f91 100644 --- a/Makefile.in +++ b/Makefile.in @@ -1087,6 +1087,14 @@ bootstrap: bootstrap-clean $(MAKE) MAKEFILE_NAME=force-Makefile force-Makefile $(MAKE) all +# The first revision to appear in the generated ChangeLog. +gen_origin = 149749a1daea874283f83a882fb2e679d1417783 +# Convert git commit log to ChangeLog file. make-dist uses this. +.PHONY: gen-ChangeLog +gen-ChangeLog: + $(AM_V_GEN)distprefix=$(distprefix) srcprefix=$(srcdir)/ \ + $(srcdir)/build-aux/gitlog-to-emacslog $(gen_origin) + .PHONY: check-declare check-declare: diff --git a/admin/admin.el b/admin/admin.el index 18ea4a4..3988977 100644 --- a/admin/admin.el +++ b/admin/admin.el @@ -28,10 +28,9 @@ (defvar add-log-time-format) ; in add-log -;; Does this information need to be in every ChangeLog, as opposed to -;; just the top-level one? Only if you allow changes the same -;; day as the release. -;; http://lists.gnu.org/archive/html/emacs-devel/2013-03/msg00161.html +;; FIXME: Update this in the light of the fact that there's only +;; one ChangeLog file now, at the top level, and it's generated from +;; commit logs by 'make-dist'. (defun add-release-logs (root version &optional date) "Add \"Version VERSION released.\" change log entries in ROOT. Root must be the root of an Emacs source tree. @@ -601,7 +600,7 @@ style=\"text-align:left\">") (copy-file "../doc/misc/texinfo.tex" stem) (or (equal type "emacs") (copy-file "../doc/emacs/emacsver.texi" stem)) (dolist (file (directory-files (format "../doc/%s" type) t)) - (if (or (string-match-p "\\(\\.texi\\'\\|/ChangeLog\\|/README\\'\\)" file) + (if (or (string-match-p "\\(\\.texi\\'\\|/README\\'\\)" file) (and (equal type "lispintro") (string-match-p "\\.\\(eps\\|pdf\\)\\'" file))) (copy-file file stem))) diff --git a/admin/authors.el b/admin/authors.el index afab6f0..de6088d 100644 --- a/admin/authors.el +++ b/admin/authors.el @@ -27,6 +27,9 @@ ;; Use M-x authors RET to create an *Authors* buffer that can used as ;; or merged with Emacs's AUTHORS file. +;; FIXME: This needs to modernized in the light of current practice, +;; which generates a single top-level ChangeLog file from commit logs. + ;;; Code: (defvar authors-coding-system 'utf-8 @@ -76,7 +79,7 @@ files.") ("Gerd Möllmann" "Gerd Moellmann") ("Hallvard B. Furuseth" "Hallvard B Furuseth" "Hallvard Furuseth") ("Hrvoje Nikšić" "Hrvoje Niksic") - ;; lisp/org/ChangeLog 2010-11-11. + ;; lisp/org/ChangeLog.1 2010-11-11. (nil "aaa bbb") (nil "Code Extracted") ; lisp/newcomment.el's "Author:" header ("Jaeyoun Chung" "Jae-youn Chung" "Jae-you Chung" "Chung Jae-youn") diff --git a/admin/make-tarball.txt b/admin/make-tarball.txt index 8f8b031..81f573f 100644 --- a/admin/make-tarball.txt +++ b/admin/make-tarball.txt @@ -2,6 +2,10 @@ Instructions to create pretest or release tarballs. -*- coding: utf-8 -*- -- originally written by Gerd Moellmann, amended by Francesco Potortì with the initial help of Eli Zaretskii +FIXME: There is now just one ChangeLog file, at the top level, +generated automatically from commit logs by 'make-dist'. The +procedure below needs to be updated accordingly. + Steps to take before starting on the first pretest in any release sequence: diff --git a/admin/merge-gnulib b/admin/merge-gnulib index 9e2b10d..e63422b 100755 --- a/admin/merge-gnulib +++ b/admin/merge-gnulib @@ -31,7 +31,7 @@ GNULIB_MODULES=' crypto/md5 crypto/sha1 crypto/sha256 crypto/sha512 dtoastr dtotimespec dup2 environ execinfo faccessat fcntl fcntl-h fdatasync fdopendir filemode fstatat fsync - getloadavg getopt-gnu gettime gettimeofday + getloadavg getopt-gnu gettime gettimeofday gitlog-to-changelog intprops largefile lstat manywarnings memrchr mkostemp mktime pipe2 pselect pthread_sigmask putenv qacl readlink readlinkat diff --git a/admin/notes/bugtracker b/admin/notes/bugtracker index fd7bd08..9d03798 100644 --- a/admin/notes/bugtracker +++ b/admin/notes/bugtracker @@ -481,7 +481,8 @@ can see exactly what the fix was. *** bug-reference-mode Activate `bug-reference-mode' in ChangeLogs to get clickable links to -the bug web-pages. +the bug web-pages. FIXME: This may need to be updated in the light of +the new policy of just one ChangeLog, at the top level. *** Debian stuff diff --git a/admin/notes/repo b/admin/notes/repo index 2d4cc2a..f76187f 100644 --- a/admin/notes/repo +++ b/admin/notes/repo @@ -47,7 +47,8 @@ removes a file, then remove the corresponding files by hand. * How to merge changes from emacs-24 to trunk -[The section on git merge procedure has not yet been written] +[The section on git merge procedure has not yet been written. +Among other things, the ChangeLog file is now automatically generated.] Inspect the change log entries (e.g. in case too many entries have been included or whitespace between entries needs fixing). If someone made diff --git a/build-aux/git-hooks/pre-commit b/build-aux/git-hooks/pre-commit index d050c40..8bce1f5 100755 --- a/build-aux/git-hooks/pre-commit +++ b/build-aux/git-hooks/pre-commit @@ -34,13 +34,15 @@ if test "$nbadchars" -ne 0; then exit 1 fi -new_names=`$git_diff HEAD` || exit -case " -$new_names" in - */-* | *' -'-*) - echo "File name component begins with '-'." - exit 1;; -esac +for new_name in `$git_diff HEAD`; do + case $new_name in + -* | */-*) + echo "$new_name: File name component begins with '-'." + exit 1;; + ChangeLog | */ChangeLog) + echo "$new_name: Please use git commit messages, not ChangeLog files." + exit 1;; + esac +done exec git diff-index --check --cached HEAD -- diff --git a/build-aux/gitlog-to-changelog b/build-aux/gitlog-to-changelog new file mode 100755 index 0000000..190f7b5 --- /dev/null +++ b/build-aux/gitlog-to-changelog @@ -0,0 +1,437 @@ +eval '(exit $?0)' && eval 'exec perl -wS "$0" ${1+"$@"}' + & eval 'exec perl -wS "$0" $argv:q' + if 0; +# Convert git log output to ChangeLog format. + +my $VERSION = '2014-11-20 17:25'; # UTC +# The definition above must lie within the first 8 lines in order +# for the Emacs time-stamp write hook (at end) to update it. +# If you change this file with Emacs, please let the write hook +# do its job. Otherwise, update this string manually. + +# Copyright (C) 2008-2014 Free Software Foundation, Inc. + +# This program 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 3 of the License, or +# (at your option) any later version. + +# This program 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 this program. If not, see . + +# Written by Jim Meyering + +use strict; +use warnings; +use Getopt::Long; +use POSIX qw(strftime); + +(my $ME = $0) =~ s|.*/||; + +# use File::Coda; # http://meyering.net/code/Coda/ +END { + defined fileno STDOUT or return; + close STDOUT and return; + warn "$ME: failed to close standard output: $!\n"; + $? ||= 1; +} + +sub usage ($) +{ + my ($exit_code) = @_; + my $STREAM = ($exit_code == 0 ? *STDOUT : *STDERR); + if ($exit_code != 0) + { + print $STREAM "Try '$ME --help' for more information.\n"; + } + else + { + print $STREAM < ChangeLog + $ME -- -n 5 foo > last-5-commits-to-branch-foo + +SPECIAL SYNTAX: + +The following types of strings are interpreted specially when they appear +at the beginning of a log message line. They are not copied to the output. + + Copyright-paperwork-exempt: Yes + Append the "(tiny change)" notation to the usual "date name email" + ChangeLog header to mark a change that does not require a copyright + assignment. + Co-authored-by: Joe User + List the specified name and email address on a second + ChangeLog header, denoting a co-author. + Signed-off-by: Joe User + These lines are simply elided. + +In a FILE specified via --amend, comment lines (starting with "#") are ignored. +FILE must consist of pairs where SHA is a 40-byte SHA1 (alone on +a line) referring to a commit in the current project, and CODE refers to one +or more consecutive lines of Perl code. Pairs must be separated by one or +more blank line. + +Here is sample input for use with --amend=FILE, from coreutils: + +3a169f4c5d9159283548178668d2fae6fced3030 +# fix typo in title: +s/all tile types/all file types/ + +1379ed974f1fa39b12e2ffab18b3f7a607082202 +# Due to a bug in vc-dwim, I mis-attributed a patch by Paul to myself. +# Change the author to be Paul. Note the escaped "@": +s,Jim .*>,Paul Eggert , + +EOF + } + exit $exit_code; +} + +# If the string $S is a well-behaved file name, simply return it. +# If it contains white space, quotes, etc., quote it, and return the new string. +sub shell_quote($) +{ + my ($s) = @_; + if ($s =~ m![^\w+/.,-]!) + { + # Convert each single quote to '\'' + $s =~ s/\'/\'\\\'\'/g; + # Then single quote the string. + $s = "'$s'"; + } + return $s; +} + +sub quoted_cmd(@) +{ + return join (' ', map {shell_quote $_} @_); +} + +# Parse file F. +# Comment lines (starting with "#") are ignored. +# F must consist of pairs where SHA is a 40-byte SHA1 +# (alone on a line) referring to a commit in the current project, and +# CODE refers to one or more consecutive lines of Perl code. +# Pairs must be separated by one or more blank line. +sub parse_amend_file($) +{ + my ($f) = @_; + + open F, '<', $f + or die "$ME: $f: failed to open for reading: $!\n"; + + my $fail; + my $h = {}; + my $in_code = 0; + my $sha; + while (defined (my $line = )) + { + $line =~ /^\#/ + and next; + chomp $line; + $line eq '' + and $in_code = 0, next; + + if (!$in_code) + { + $line =~ /^([0-9a-fA-F]{40})$/ + or (warn "$ME: $f:$.: invalid line; expected an SHA1\n"), + $fail = 1, next; + $sha = lc $1; + $in_code = 1; + exists $h->{$sha} + and (warn "$ME: $f:$.: duplicate SHA1\n"), + $fail = 1, next; + } + else + { + $h->{$sha} ||= ''; + $h->{$sha} .= "$line\n"; + } + } + close F; + + $fail + and exit 1; + + return $h; +} + +# git_dir_option $SRCDIR +# +# From $SRCDIR, the --git-dir option to pass to git (none if $SRCDIR +# is undef). Return as a list (0 or 1 element). +sub git_dir_option($) +{ + my ($srcdir) = @_; + my @res = (); + if (defined $srcdir) + { + my $qdir = shell_quote $srcdir; + my $cmd = "cd $qdir && git rev-parse --show-toplevel"; + my $qcmd = shell_quote $cmd; + my $git_dir = qx($cmd); + defined $git_dir + or die "$ME: cannot run $qcmd: $!\n"; + $? == 0 + or die "$ME: $qcmd had unexpected exit code or signal ($?)\n"; + chomp $git_dir; + push @res, "--git-dir=$git_dir/.git"; + } + @res; +} + +{ + my $since_date; + my $until_date; + my $format_string = '%s%n%b%n'; + my $amend_file; + my $append_dot = 0; + my $cluster = 1; + my $strip_tab = 0; + my $strip_cherry_pick = 0; + my $srcdir; + GetOptions + ( + help => sub { usage 0 }, + version => sub { print "$ME version $VERSION\n"; exit }, + 'since=s' => \$since_date, + 'until=s' => \$until_date, + 'format=s' => \$format_string, + 'amend=s' => \$amend_file, + 'append-dot' => \$append_dot, + 'cluster!' => \$cluster, + 'strip-tab' => \$strip_tab, + 'strip-cherry-pick' => \$strip_cherry_pick, + 'srcdir=s' => \$srcdir, + ) or usage 1; + + defined $since_date + and unshift @ARGV, "--since=$since_date"; + defined $until_date + and unshift @ARGV, "--until=$until_date"; + + # This is a hash that maps an SHA1 to perl code (i.e., s/old/new/) + # that makes a correction in the log or attribution of that commit. + my $amend_code = defined $amend_file ? parse_amend_file $amend_file : {}; + + my @cmd = ('git', + git_dir_option $srcdir, + qw(log --log-size), + '--pretty=format:%H:%ct %an <%ae>%n%n'.$format_string, @ARGV); + open PIPE, '-|', @cmd + or die ("$ME: failed to run '". quoted_cmd (@cmd) ."': $!\n" + . "(Is your Git too old? Version 1.5.1 or later is required.)\n"); + + my $prev_multi_paragraph; + my $prev_date_line = ''; + my @prev_coauthors = (); + while (1) + { + defined (my $in = ) + or last; + $in =~ /^log size (\d+)$/ + or die "$ME:$.: Invalid line (expected log size):\n$in"; + my $log_nbytes = $1; + + my $log; + my $n_read = read PIPE, $log, $log_nbytes; + $n_read == $log_nbytes + or die "$ME:$.: unexpected EOF\n"; + + # Extract leading hash. + my ($sha, $rest) = split ':', $log, 2; + defined $sha + or die "$ME:$.: malformed log entry\n"; + $sha =~ /^[0-9a-fA-F]{40}$/ + or die "$ME:$.: invalid SHA1: $sha\n"; + + # If this commit's log requires any transformation, do it now. + my $code = $amend_code->{$sha}; + if (defined $code) + { + eval 'use Safe'; + my $s = new Safe; + # Put the unpreprocessed entry into "$_". + $_ = $rest; + + # Let $code operate on it, safely. + my $r = $s->reval("$code") + or die "$ME:$.:$sha: failed to eval \"$code\":\n$@\n"; + + # Note that we've used this entry. + delete $amend_code->{$sha}; + + # Update $rest upon success. + $rest = $_; + } + + # Remove lines inserted by "git cherry-pick". + if ($strip_cherry_pick) + { + $rest =~ s/^\s*Conflicts:\n.*//sm; + $rest =~ s/^\s*\(cherry picked from commit [\da-f]+\)\n//m; + } + + my @line = split "\n", $rest; + my $author_line = shift @line; + defined $author_line + or die "$ME:$.: unexpected EOF\n"; + $author_line =~ /^(\d+) (.*>)$/ + or die "$ME:$.: Invalid line " + . "(expected date/author/email):\n$author_line\n"; + + # Format 'Copyright-paperwork-exempt: Yes' as a standard ChangeLog + # `(tiny change)' annotation. + my $tiny = (grep (/^Copyright-paperwork-exempt:\s+[Yy]es$/, @line) + ? ' (tiny change)' : ''); + + my $date_line = sprintf "%s %s$tiny\n", + strftime ("%F", localtime ($1)), $2; + + my @coauthors = grep /^Co-authored-by:.*$/, @line; + # Omit meta-data lines we've already interpreted. + @line = grep !/^(?:Signed-off-by:[ ].*>$ + |Co-authored-by:[ ] + |Copyright-paperwork-exempt:[ ] + )/x, @line; + + # Remove leading and trailing blank lines. + if (@line) + { + while ($line[0] =~ /^\s*$/) { shift @line; } + while ($line[$#line] =~ /^\s*$/) { pop @line; } + } + + # Record whether there are two or more paragraphs. + my $multi_paragraph = grep /^\s*$/, @line; + + # Format 'Co-authored-by: A U Thor ' lines in + # standard multi-author ChangeLog format. + for (@coauthors) + { + s/^Co-authored-by:\s*/\t /; + s/\s*/ + or warn "$ME: warning: missing email address for " + . substr ($_, 5) . "\n"; + } + + # If clustering of commit messages has been disabled, if this header + # would be different from the previous date/name/email/coauthors header, + # or if this or the previous entry consists of two or more paragraphs, + # then print the header. + if ( ! $cluster + || $date_line ne $prev_date_line + || "@coauthors" ne "@prev_coauthors" + || $multi_paragraph + || $prev_multi_paragraph) + { + $prev_date_line eq '' + or print "\n"; + print $date_line; + @coauthors + and print join ("\n", @coauthors), "\n"; + } + $prev_date_line = $date_line; + @prev_coauthors = @coauthors; + $prev_multi_paragraph = $multi_paragraph; + + # If there were any lines + if (@line == 0) + { + warn "$ME: warning: empty commit message:\n $date_line\n"; + } + else + { + if ($append_dot) + { + # If the first line of the message has enough room, then + if (length $line[0] < 72) + { + # append a dot if there is no other punctuation or blank + # at the end. + $line[0] =~ /[[:punct:]\s]$/ + or $line[0] .= '.'; + } + } + + # Remove one additional leading TAB from each line. + $strip_tab + and map { s/^\t// } @line; + + # Prefix each non-empty line with a TAB. + @line = map { length $_ ? "\t$_" : '' } @line; + + print "\n", join ("\n", @line), "\n"; + } + + defined ($in = ) + or last; + $in ne "\n" + and die "$ME:$.: unexpected line:\n$in"; + } + + close PIPE + or die "$ME: error closing pipe from " . quoted_cmd (@cmd) . "\n"; + # FIXME-someday: include $PROCESS_STATUS in the diagnostic + + # Complain about any unused entry in the --amend=F specified file. + my $fail = 0; + foreach my $sha (keys %$amend_code) + { + warn "$ME:$amend_file: unused entry: $sha\n"; + $fail = 1; + } + + exit $fail; +} + +# Local Variables: +# mode: perl +# indent-tabs-mode: nil +# eval: (add-hook 'write-file-hooks 'time-stamp) +# time-stamp-start: "my $VERSION = '" +# time-stamp-format: "%:y-%02m-%02d %02H:%02M" +# time-stamp-time-zone: "UTC" +# time-stamp-end: "'; # UTC" +# End: diff --git a/build-aux/gitlog-to-emacslog b/build-aux/gitlog-to-emacslog new file mode 100755 index 0000000..8ea8112 --- /dev/null +++ b/build-aux/gitlog-to-emacslog @@ -0,0 +1,49 @@ +#!/bin/sh + +# Convert git log output to ChangeLog format for GNU Emacs. + +# Copyright (C) 2014 Free Software Foundation, Inc. + +# This program 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 3 of the License, or +# (at your option) any later version. + +# This program 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 this program. If not, see . + +LC_ALL=C +export LC_ALL + +gen_origin=${1?} +shift + +if test -d ${srcprefix}.git; then + gen_origin_date=`git log --pretty=format:%ci "$gen_origin"^! ` || exit + gen_start_year=`expr "$gen_origin_date" : '\([^-]*\)'` || exit + log_fix="${srcprefix}build-aux/git-log-fix" + test -e "$log_fix" && set -- "$@" --amend="$log_fix" + + ${srcprefix}build-aux/gitlog-to-changelog "$@" $gen_origin^.. \ + > ${distprefix}cl-t || exit + + gen_end_year=`sed 's/-.*//; q' ${distprefix}cl-t` + if test "$gen_start_year" = "$gen_end_year"; then + year_range=$gen_start_year + else + year_range=$gen_start_year-$gen_end_year + fi + + sed "1d + s/Copyright (C) [0-9]*-[0-9]*/Copyright (C) $year_range/ + s/^# // + /http:/q + " Makefile.in >>${distprefix}cl-t && + rm -f ${distprefix}ChangeLog && + mv ${distprefix}cl-t ${distprefix}ChangeLog +fi diff --git a/lisp/calendar/icalendar.el b/lisp/calendar/icalendar.el index 452a672..da5d85e 100644 --- a/lisp/calendar/icalendar.el +++ b/lisp/calendar/icalendar.el @@ -39,7 +39,7 @@ ;;; History: -;; 0.07 onwards: see lisp/ChangeLog +;; 0.07 onwards: see commit logs and ../ChangeLog*. ;; 0.06: (2004-10-06) ;; - Bugfixes regarding icalendar-import-format-*. diff --git a/lisp/gnus/deuglify.el b/lisp/gnus/deuglify.el index 00d1ee9..92f2c00 100644 --- a/lisp/gnus/deuglify.el +++ b/lisp/gnus/deuglify.el @@ -188,7 +188,7 @@ ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; -;; See ChangeLog for other changes. +;; See commit log or ChangeLog* for other changes. ;; ;; Revision 1.5 2002/01/27 14:39:17 rscholz ;; * New variable `gnus-outlook-deuglify-no-wrap-chars' to inhibit diff --git a/lisp/obsolete/gulp.el b/lisp/obsolete/gulp.el index 5ff99f2..f0223fa 100644 --- a/lisp/obsolete/gulp.el +++ b/lisp/obsolete/gulp.el @@ -70,7 +70,7 @@ please send them to me ASAP. Please don't send the whole file. Instead, please send a patch made with `diff -c' that shows precisely the changes you would like me to install. Also please include itemized change log entries for your changes; -please use lisp/ChangeLog as a guide for the style and for what kinds +please use lisp/ChangeLog* as a guide for the style and for what kinds of information to include. Thanks.") diff --git a/lwlib/README b/lwlib/README index 25c72eb..ed7583d 100644 --- a/lwlib/README +++ b/lwlib/README @@ -4,4 +4,4 @@ library was written by Lucid, Inc and released under the terms of the GPL version 1 (or later). It is not considered part of GNU Emacs. This version of the library differs from the original as described in -the ChangeLog file. +the ChangeLog.1 file. diff --git a/make-dist b/make-dist index 4e05594..f66a0db 100755 --- a/make-dist +++ b/make-dist @@ -277,13 +277,20 @@ fi echo "Creating top directory: \`${tempdir}'" mkdir ${tempdir} +if test -d .git; then + echo "Making top-level ChangeLog" + make distprefix=${tempdir}/ gen-ChangeLog +else + echo "No repository, so omitting top-level ChangeLog" +fi + ### We copy in the top-level files before creating the subdirectories in ### hopes that this will make the top-level files appear first in the ### tar file; this means that people can start reading the INSTALL and ### README while the rest of the tar file is still unpacking. Whoopee. echo "Making links to top-level files" ln INSTALL README BUGS ${tempdir} -ln ChangeLog Makefile.in autogen.sh configure configure.ac ${tempdir} +ln ChangeLog.*[0-9] Makefile.in autogen.sh configure configure.ac ${tempdir} ln config.bat make-dist .dir-locals.el ${tempdir} ln aclocal.m4 ${tempdir} @@ -333,7 +340,7 @@ done echo "Making links to \`leim' and its subdirectories" (cd leim ln makefile.w32-in ../${tempdir}/leim - ln ChangeLog README ../${tempdir}/leim + ln ChangeLog.*[0-9] README ../${tempdir}/leim ln CXTERM-DIC/README CXTERM-DIC/*.tit ../${tempdir}/leim/CXTERM-DIC ln SKK-DIC/README SKK-DIC/SKK-JISYO.L ../${tempdir}/leim/SKK-DIC ln MISC-DIC/README MISC-DIC/*.* ../${tempdir}/leim/MISC-DIC @@ -344,6 +351,7 @@ echo "Making links to \`leim' and its subdirectories" echo "Making links to \`build-aux'" (cd build-aux ln compile config.guess config.sub depcomp msys-to-w32 ../${tempdir}/build-aux + ln gitlog-to-changelog ../${tempdir}/build-aux ln install-sh missing move-if-change ../${tempdir}/build-aux ln update-copyright update-subdirs ../${tempdir}/build-aux ln dir_top make-info-dir ../${tempdir}/build-aux) @@ -360,7 +368,7 @@ echo "Making links to \`src'" ln [a-zA-Z]*.[chm] ../${tempdir}/src ln [a-zA-Z]*.in ../${tempdir}/src ln [a-zA-Z]*.mk ../${tempdir}/src - ln README ChangeLog ChangeLog.*[0-9] ../${tempdir}/src + ln README ChangeLog.*[0-9] ../${tempdir}/src ln makefile.w32-in ../${tempdir}/src ln .gdbinit .dbxinit ../${tempdir}/src cd ../${tempdir}/src @@ -398,7 +406,7 @@ echo "Making links to \`nt'" ln nmake.defs gmake.defs subdirs.el [a-z]*.bat [a-z]*.[ch] ../${tempdir}/nt ln *.in gnulib.mk ../${tempdir}/nt ln mingw-cfg.site epaths.nt INSTALL.OLD ../${tempdir}/nt - ln ChangeLog INSTALL README README.W32 makefile.w32-in ../${tempdir}/nt) + ln ChangeLog.*[0-9] INSTALL README README.W32 makefile.w32-in ../${tempdir}/nt) echo "Making links to \`nt/inc' and its subdirectories" for f in `find nt/inc -type f -name '[a-z]*.h'`; do -- 2.1.0 --------------030803080100020902000203--