diff options
author | Markus Rost <rost@math.uni-bielefeld.de> | 2002-09-24 18:40:59 +0000 |
---|---|---|
committer | Markus Rost <rost@math.uni-bielefeld.de> | 2002-09-24 18:40:59 +0000 |
commit | 9f4b608417309d0480fe17f679d1173cbc534b6f (patch) | |
tree | 485b1eea7fe8691be3cb4556b141d8fb127953c3 | |
parent | 2f552813381994f6bd1ffa56f7179a6d919a351f (diff) | |
download | emacs-9f4b608417309d0480fe17f679d1173cbc534b6f.tar.gz |
(edit-and-eval-command): Protect command-history.
(repeat-complex-command): Protect command-history.
-rw-r--r-- | lisp/ChangeLog | 5 | ||||
-rw-r--r-- | lisp/simple.el | 36 |
2 files changed, 25 insertions, 16 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 2a18f67df08..b1f58215d58 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,8 @@ +2002-09-24 Markus Rost <rost@math.ohio-state.edu> + + * simple.el (edit-and-eval-command): Protect command-history. + (repeat-complex-command): Protect command-history. + 2002-09-24 Juanma Barranquero <lektu@terra.es> * replace.el (occur-find-match): New function. diff --git a/lisp/simple.el b/lisp/simple.el index d94d497180d..ecf0e95a620 100644 --- a/lisp/simple.el +++ b/lisp/simple.el @@ -650,14 +650,16 @@ the echo area." "Prompting with PROMPT, let user edit COMMAND and eval result. COMMAND is a Lisp expression. Let user edit that expression in the minibuffer, then read and evaluate the result." - (let ((command (read-from-minibuffer prompt - (prin1-to-string command) - read-expression-map t - '(command-history . 1)))) - ;; If command was added to command-history as a string, - ;; get rid of that. We want only evaluable expressions there. - (if (stringp (car command-history)) - (setq command-history (cdr command-history))) + (let ((command + (unwind-protect + (read-from-minibuffer prompt + (prin1-to-string command) + read-expression-map t + '(command-history . 1)) + ;; If command was added to command-history as a string, + ;; get rid of that. We want only evaluable expressions there. + (if (stringp (car command-history)) + (setq command-history (cdr command-history)))))) ;; If command to be redone does not match front of history, ;; add it to the history. @@ -683,14 +685,16 @@ to get different commands to edit and resubmit." (let ((print-level nil) (minibuffer-history-position arg) (minibuffer-history-sexp-flag (1+ (minibuffer-depth)))) - (read-from-minibuffer - "Redo: " (prin1-to-string elt) read-expression-map t - (cons 'command-history arg)))) - - ;; If command was added to command-history as a string, - ;; get rid of that. We want only evaluable expressions there. - (if (stringp (car command-history)) - (setq command-history (cdr command-history))) + (unwind-protect + (read-from-minibuffer + "Redo: " (prin1-to-string elt) read-expression-map t + (cons 'command-history arg)) + + ;; If command was added to command-history as a + ;; string, get rid of that. We want only + ;; evaluable expressions there. + (if (stringp (car command-history)) + (setq command-history (cdr command-history)))))) ;; If command to be redone does not match front of history, ;; add it to the history. |