changeset 105030:8da5090a59d7

(byte-compile-refresh-preloaded): New function.
author Stefan Monnier <monnier@iro.umontreal.ca>
date Tue, 15 Sep 2009 04:03:35 +0000
parents 4859f3f9f0dc
children 7700dc1d76fd
files lisp/ChangeLog lisp/emacs-lisp/bytecomp.el
diffstat 2 files changed, 24 insertions(+), 1 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/ChangeLog	Tue Sep 15 03:46:05 2009 +0000
+++ b/lisp/ChangeLog	Tue Sep 15 04:03:35 2009 +0000
@@ -1,5 +1,7 @@
 2009-09-15  Stefan Monnier  <monnier@iro.umontreal.ca>
 
+	* emacs-lisp/bytecomp.el (byte-compile-refresh-preloaded): New function.
+
 	* loadup.el: Use after-load-functions to GC after loading each file.
 	Remove the explicit GC calls that used to be sprinkled around.
 
--- a/lisp/emacs-lisp/bytecomp.el	Tue Sep 15 03:46:05 2009 +0000
+++ b/lisp/emacs-lisp/bytecomp.el	Tue Sep 15 04:03:35 2009 +0000
@@ -4103,7 +4103,8 @@
     (byte-compile-form (cons 'progn (cdr form)))))
 
 ;; Warn about misuses of make-variable-buffer-local.
-(byte-defop-compiler-1 make-variable-buffer-local byte-compile-make-variable-buffer-local)
+(byte-defop-compiler-1 make-variable-buffer-local
+                       byte-compile-make-variable-buffer-local)
 (defun byte-compile-make-variable-buffer-local (form)
   (if (and (eq (car-safe (car-safe (cdr-safe form))) 'quote)
            (byte-compile-warning-enabled-p 'make-local))
@@ -4394,6 +4395,26 @@
        nil))))
 
 ;;;###autoload
+(defun byte-compile-refresh-preloaded ()
+  "Reload any Lisp file that was changed since Emacs was dumped.
+Use with caution."
+  (let* ((argv0 (car command-line-args))
+         (emacs-file (executable-find argv0)))
+    (if (not (and emacs-file (file-executable-p emacs-file)))
+        (message "Can't find %s to refresh preloaded Lisp files" argv0)
+      (dolist (f (reverse load-history))
+        (setq f (car f))
+        (if (string-match "elc\\'" f) (setq f (substring f 0 -1)))
+        (when (and (file-readable-p f)
+                   (file-newer-than-file-p f emacs-file))
+          (message "Reloading stale %s" (file-name-nondirectory f))
+          (condition-case nil
+              (load f 'noerror nil 'nosuffix)
+            ;; Probably shouldn't happen, but in case of an error, it seems
+            ;; at least as useful to ignore it as it is to stop compilation.
+            (error nil)))))))
+
+;;;###autoload
 (defun batch-byte-recompile-directory (&optional arg)
   "Run `byte-recompile-directory' on the dirs remaining on the command line.
 Must be used only with `-batch', and kills Emacs on completion.