]> git.eshelyaron.com Git - emacs.git/commitdiff
Add emacs-bzr-version
authorGlenn Morris <rgm@gnu.org>
Sat, 7 Apr 2012 19:51:51 +0000 (12:51 -0700)
committerGlenn Morris <rgm@gnu.org>
Sat, 7 Apr 2012 19:51:51 +0000 (12:51 -0700)
* lisp/version.el (emacs-bzr-get-version): New function.
* lisp/loadup.el (emacs-bzr-version): Set it.
* lisp/mail/emacsbug.el (report-emacs-bug): Include bzr version.

* etc/NEWS: Mention this, though it is not really relevant to releases.
Insert template for 24.2 release.

Fixes: debbugs:8054
etc/NEWS
lisp/ChangeLog
lisp/loadup.el
lisp/mail/emacsbug.el
lisp/version.el

index f97003d8fd072b6502fa890a112fd9fa0a592947..ae6ba8d36b772879da935622a43536896c45c255 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1,6 +1,6 @@
 GNU Emacs NEWS -- history of user-visible changes.
 
-Copyright (C) 2010-2012  Free Software Foundation, Inc.
+Copyright (C) 2010-2012 Free Software Foundation, Inc.
 See the end of the file for license conditions.
 
 Please send Emacs bug reports to bug-gnu-emacs@gnu.org.
@@ -14,6 +14,32 @@ and NEWS.1-17 for changes in older Emacs versions.
 You can narrow news to a specific version by calling `view-emacs-news'
 with a prefix argument or by typing C-u C-h C-n.
 
+Temporary note:
++++ indicates that the appropriate manual has already been updated.
+--- means no change in the manuals is called for.
+When you add a new item, please add it without either +++ or ---
+so we will look at it and add it to the manual.
+
+\f
+* Installation Changes in Emacs 24.2
+\f
+* Startup Changes in Emacs 24.2
+\f
+* Changes in Emacs 24.2
+
+** If your Emacs was built from a bzr checkout, the new variable
+`emacs-bzr-version' contains information about which bzr revision was used.
+
+\f
+* Editing Changes in Emacs 24.2
+\f
+* Changes in Specialized Modes and Packages in Emacs 24.2
+\f
+* New Modes and Packages in Emacs 24.2
+\f
+* Incompatible Lisp Changes in Emacs 24.2
+\f
+* Lisp changes in Emacs 24.2
 \f
 * Changes in Emacs 24.2 on non-free operating systems
 
index 027b6631639c34a1499383f27874e24e50451478..179b7ff3a31c074203b2f171c44b6a263cf7af28 100644 (file)
@@ -1,3 +1,9 @@
+2012-04-07  Glenn Morris  <rgm@gnu.org>
+
+       * version.el (emacs-bzr-get-version): New function.
+       * loadup.el (emacs-bzr-version): Set it.  (Bug#8054)
+       * mail/emacsbug.el (report-emacs-bug): Include bzr version.
+
 2012-04-07  Eli Zaretskii  <eliz@gnu.org>
 
        * international/uni-bidi.el:
index b7af41d6246f1d6f3c7d53efb46e4cb4d1ca8342..16cd0171e618c4d025f54b4c345e1f223b5fb562 100644 (file)
           (versions (mapcar (function (lambda (name)
                                         (string-to-number (substring name (length base)))))
                             files)))
+      (setq emacs-bzr-version (condition-case nil (emacs-bzr-get-version)
+                              (error nil)))
       ;; `emacs-version' is a constant, so we shouldn't change it with `setq'.
       (defconst emacs-version
        (format "%s.%d"
index 1a02ae7c5193c90563524a0eaa1b6ce926f736e9..33b73335a7d937adcddf09f63947027ed6a9be65 100644 (file)
@@ -239,6 +239,8 @@ usually do not have translators for other languages.\n\n")))
     (add-text-properties (1+ user-point) (point) prompt-properties)
 
     (insert "\n\nIn " (emacs-version) "\n")
+    (if (stringp emacs-bzr-version)
+       (insert "Bzr revision: " emacs-bzr-version "\n"))
     (if (fboundp 'x-server-vendor)
        (condition-case nil
             ;; This is used not only for X11 but also W32 and others.
index bd30f0f81b8ca642e8772d16e0ebb089ff125b6f..a4bc4fd54a6244d0b98fe6105093bcc3d766198e 100644 (file)
@@ -79,6 +79,26 @@ to the system configuration; look at `system-configuration' instead."
 ;; We hope that this alias is easier for people to find.
 (defalias 'version 'emacs-version)
 
+;; Set during dumping, this is a defvar so that it can be setq'd.
+(defvar emacs-bzr-version nil "\
+String giving the bzr revision number from which this Emacs was built.
+This is nil if Emacs was not built from a bzr checkout, or if we could
+not determine the revision.")
+
+(defun emacs-bzr-get-version () "\
+Try to return as a string the bzr revision number of the Emacs sources.
+Returns nil if the sources do not seem to be under bzr, or if we could
+not determine the revision.  Note that this reports on the current state
+of the sources, which may not correspond to the running Emacs."
+  (let ((file (expand-file-name ".bzr/branch/last-revision" source-directory)))
+    (if (file-readable-p file)
+        (with-temp-buffer
+          (insert-file-contents file)
+          (goto-char (point-max))
+          (if (looking-back "\n")
+              (delete-char -1))
+          (buffer-string)))))
+
 ;; We put version info into the executable in the form that `ident' uses.
 (or (eq system-type 'windows-nt)
     (purecopy (concat "\n$Id: " (subst-char-in-string ?\n ?\s (emacs-version))