Mercurial > emacs
changeset 14719:d477c6f756df
Save if reqd in emacs-lisp-byte-compile-and-load.
author | Simon Marshall <simon@gnu.org> |
---|---|
date | Thu, 29 Feb 1996 08:19:46 +0000 |
parents | cb80e4399021 |
children | 52a6ccf7c0a8 |
files | lisp/emacs-lisp/lisp-mode.el |
diffstat | 1 files changed, 9 insertions(+), 7 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/emacs-lisp/lisp-mode.el Thu Feb 29 00:32:15 1996 +0000 +++ b/lisp/emacs-lisp/lisp-mode.el Thu Feb 29 08:19:46 1996 +0000 @@ -155,7 +155,7 @@ (define-key map [byte-recompile] '("Byte-recompile Directory..." . byte-recompile-directory)) (define-key map [emacs-byte-compile-and-load] - '("Byte-compile And Load" . emacs-lisp-compile-and-load)) + '("Byte-compile And Load" . emacs-lisp-byte-compile-and-load)) (define-key map [byte-compile] '("Byte-compile This File" . emacs-lisp-byte-compile)) (define-key map [separator-eval] '("--")) @@ -177,18 +177,20 @@ (byte-compile-file buffer-file-name) (error "The buffer must be saved in a file first"))) -(defun emacs-lisp-compile-and-load () +(defun emacs-lisp-byte-compile-and-load () "Byte-compile the current file (if it has changed), then load compiled code." (interactive) (or buffer-file-name (error "The buffer must be saved in a file first")) (require 'bytecomp) ;; Recompile if file or buffer has changed since last compilation. - (or (buffer-modified-p) - (file-newer-than-file-p (byte-compile-dest-file buffer-file-name) - buffer-file-name) - (byte-compile-file buffer-file-name)) - (load-file (byte-compile-dest-file buffer-file-name))) + (if (and (buffer-modified-p) + (y-or-n-p (format "save buffer %s first? " (buffer-name)))) + (save-buffer)) + (let ((compiled-file-name (byte-compile-dest-file buffer-file-name))) + (if (file-newer-than-file-p compiled-file-name buffer-file-name) + (load-file compiled-file-name) + (byte-compile-file buffer-file-name t)))) (defun emacs-lisp-mode () "Major mode for editing Lisp code to run in Emacs.