Mercurial > emacs
changeset 21490:366a1d025c6c
(eval-defun): Arrange to use eval-region
even if we have to alter the form.
author | Karl Heuer <kwzh@gnu.org> |
---|---|
date | Mon, 13 Apr 1998 06:55:34 +0000 |
parents | a1a2beb0a09c |
children | 7a8169a735f5 |
files | lisp/emacs-lisp/lisp-mode.el |
diffstat | 1 files changed, 18 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/emacs-lisp/lisp-mode.el Mon Apr 13 06:42:31 1998 +0000 +++ b/lisp/emacs-lisp/lisp-mode.el Mon Apr 13 06:55:34 1998 +0000 @@ -342,10 +342,14 @@ With argument, insert value in current buffer after the defun." (interactive "P") (let ((standard-output (if eval-defun-arg-internal (current-buffer) t)) - (form (save-excursion - (end-of-defun) - (beginning-of-defun) - (read (current-buffer))))) + end form) + ;; Read the form from the buffer, and record where it ends. + (save-excursion + (end-of-defun) + (beginning-of-defun) + (setq form (read (current-buffer))) + (setq end (point))) + ;; Alter the form if necessary. (cond ((and (eq (car form) 'defvar) (cdr-safe (cdr-safe form))) ;; Force variable to be bound. @@ -354,7 +358,16 @@ (default-boundp (nth 1 form))) ;; Force variable to be bound. (set-default (nth 1 form) (eval (nth 2 form))))) - (prin1 (eval form)))) + ;; Now arrange for eval-region to "read" the (possibly) altered form. + ;; eval-region handles recording which file defines a function or variable. + (save-excursion + (let ((load-read-function + #'(lambda (ignore) + ;; Skipping to the end of the specified region + ;; will make eval-region return. + (goto-char end) + form))) + (eval-region (point) end standard-output))))) (defun lisp-comment-indent () (if (looking-at "\\s<\\s<\\s<")