diff options
author | Stefan Monnier <monnier@iro.umontreal.ca> | 2009-11-13 22:19:45 +0000 |
---|---|---|
committer | Stefan Monnier <monnier@iro.umontreal.ca> | 2009-11-13 22:19:45 +0000 |
commit | 7fdbcd83877ab0317df43e1120c583af3ba86bc4 (patch) | |
tree | 6a12415c3510f96fdd1574a39ec9c64a216bbcac /lisp/term.el | |
parent | 2ccbc060d2fe48e6eba6a04a0bf579152055ccba (diff) | |
download | emacs-7fdbcd83877ab0317df43e1120c583af3ba86bc4.tar.gz |
* x-dnd.el (x-dnd-maybe-call-test-function):
* window.el (split-window-vertically):
* whitespace.el (whitespace-help-on):
* vc-rcs.el (vc-rcs-consult-headers):
* userlock.el (ask-user-about-lock-help)
(ask-user-about-supersession-help):
* type-break.el (type-break-force-mode-line-update):
* time-stamp.el (time-stamp-conv-warn):
* terminal.el (te-set-output-log, te-more-break, te-filter)
(te-sentinel,terminal-emulator):
* term.el (make-term, term-exec, term-sentinel, term-read-input-ring)
(term-write-input-ring, term-check-source, term-start-output-log):
(term-display-buffer-line, term-dynamic-list-completions):
(term-ansi-make-term, serial-term):
* subr.el (selective-display):
* strokes.el (strokes-xpm-to-compressed-string, strokes-decode-buffer)
(strokes-encode-buffer, strokes-xpm-for-compressed-string):
* speedbar.el (speedbar-buffers-tail-notes, speedbar-buffers-item-info)
(speedbar-reconfigure-keymaps, speedbar-add-localized-speedbar-support)
(speedbar-remove-localized-speedbar-support)
(speedbar-set-mode-line-format, speedbar-create-tag-hierarchy)
(speedbar-update-special-contents, speedbar-buffer-buttons-engine)
(speedbar-buffers-line-directory):
* simple.el (shell-command-on-region, append-to-buffer)
(prepend-to-buffer):
* shadowfile.el (shadow-save-todo-file):
* scroll-bar.el (scroll-bar-set-window-start, scroll-bar-drag-1)
(scroll-bar-maybe-set-window-start):
* sb-image.el (speedbar-image-dump):
* saveplace.el (save-place-alist-to-file, save-places-to-alist)
(load-save-place-alist-from-file):
* ps-samp.el (ps-print-message-from-summary):
* ps-print.el (ps-flush-output, ps-insert-file, ps-get-boundingbox)
(ps-background-image, ps-begin-job, ps-do-despool):
* ps-bdf.el (bdf-find-file, bdf-read-font-info):
* printing.el (pr-interface, pr-ps-file-print, pr-find-buffer-visiting)
(pr-ps-message-from-summary, pr-lpr-message-from-summary):
(pr-call-process, pr-file-list, pr-interface-save):
* novice.el (disabled-command-function)
(enable-command, disable-command):
* mouse.el (mouse-buffer-menu-alist):
* mouse-copy.el (mouse-kill-preserving-secondary):
* macros.el (kbd-macro-query):
* ledit.el (ledit-go-to-lisp, ledit-go-to-liszt):
* informat.el (batch-info-validate):
* ido.el (ido-copy-current-word, ido-initiate-auto-merge):
* hippie-exp.el (try-expand-dabbrev-visible):
* help-mode.el (help-make-xrefs):
* help-fns.el (describe-variable):
* generic-x.el (bat-generic-mode-run-as-comint):
* finder.el (finder-mouse-select):
* find-dired.el (find-dired-sentinel):
* filesets.el (filesets-file-close):
* files.el (list-directory):
* faces.el (list-faces-display, describe-face):
* facemenu.el (list-colors-display):
* ezimage.el (ezimage-image-association-dump, ezimage-image-dump):
* epg.el (epg--process-filter, epg-cancel):
* epa.el (epa--marked-keys, epa--select-keys, epa-display-info)
(epa--read-signature-type):
* emerge.el (emerge-copy-as-kill-A, emerge-copy-as-kill-B)
(emerge-file-names):
* ehelp.el (electric-helpify):
* ediff.el (ediff-regions-wordwise, ediff-regions-linewise):
* ediff-vers.el (rcs-ediff-view-revision):
* ediff-util.el (ediff-setup):
* ediff-mult.el (ediff-append-custom-diff):
* ediff-diff.el (ediff-exec-process, ediff-process-sentinel)
(ediff-wordify):
* echistory.el (Electric-command-history-redo-expression):
* dos-w32.el (find-file-not-found-set-buffer-file-coding-system):
* disp-table.el (describe-display-table):
* dired.el (dired-find-buffer-nocreate):
* dired-aux.el (dired-rename-subdir, dired-dwim-target-directory):
* dabbrev.el (dabbrev--same-major-mode-p):
* chistory.el (list-command-history):
* apropos.el (apropos-documentation):
* allout.el (allout-obtain-passphrase):
(allout-copy-exposed-to-buffer):
(allout-verify-passphrase): Use with-current-buffer.
Diffstat (limited to 'lisp/term.el')
-rw-r--r-- | lisp/term.el | 61 |
1 files changed, 21 insertions, 40 deletions
diff --git a/lisp/term.el b/lisp/term.el index 97d2fa5a74e..61dd3f415f0 100644 --- a/lisp/term.el +++ b/lisp/term.el @@ -1347,8 +1347,7 @@ the process. Any more args are arguments to PROGRAM." ;; If no process, or nuked process, crank up a new one and put buffer in ;; term mode. Otherwise, leave buffer and existing process alone. (cond ((not (term-check-proc buffer)) - (save-excursion - (set-buffer buffer) + (with-current-buffer buffer (term-mode)) ; Install local vars, mode, keymap, ... (term-exec buffer name program startfile switches))) buffer)) @@ -1375,8 +1374,7 @@ commands to use in that buffer. Blasts any old process running in the buffer. Doesn't set the buffer mode. You can use this to cheaply run a series of processes in the same term buffer. The hook `term-exec-hook' is run after each exec." - (save-excursion - (set-buffer buffer) + (with-current-buffer buffer (let ((proc (get-buffer-process buffer))) ; Blast any old process. (when proc (delete-process proc))) ;; Crank up a new process @@ -1412,24 +1410,16 @@ The main purpose is to get rid of the local keymap." (if (null (buffer-name buffer)) ;; buffer killed (set-process-buffer proc nil) - (let ((obuf (current-buffer))) - ;; save-excursion isn't the right thing if - ;; process-buffer is current-buffer - (unwind-protect - (progn - ;; Write something in the compilation buffer - ;; and hack its mode line. - (set-buffer buffer) - ;; Get rid of local keymap. - (use-local-map nil) - (term-handle-exit (process-name proc) - msg) - ;; Since the buffer and mode line will show that the - ;; process is dead, we can delete it now. Otherwise it - ;; will stay around until M-x list-processes. - (delete-process proc)) - (set-buffer obuf))) - )))) + (with-current-buffer buffer + ;; Write something in the compilation buffer + ;; and hack its mode line. + ;; Get rid of local keymap. + (use-local-map nil) + (term-handle-exit (process-name proc) msg) + ;; Since the buffer and mode line will show that the + ;; process is dead, we can delete it now. Otherwise it + ;; will stay around until M-x list-processes. + (delete-process proc)))))) (defun term-handle-exit (process-name msg) "Write process exit (or other change) message MSG in the current buffer." @@ -1557,8 +1547,7 @@ See also `term-input-ignoredups' and `term-write-input-ring'." (count 0) (ring (make-ring term-input-ring-size))) (unwind-protect - (save-excursion - (set-buffer history-buf) + (with-current-buffer history-buf (widen) (erase-buffer) (insert-file-contents file) @@ -1601,8 +1590,7 @@ See also `term-read-input-ring'." (index (ring-length ring))) ;; Write it all out into a buffer first. Much faster, but messier, ;; than writing it one line at a time. - (save-excursion - (set-buffer history-buf) + (with-current-buffer history-buf (erase-buffer) (while (> index 0) (setq index (1- index)) @@ -2460,10 +2448,8 @@ See `term-prompt-regexp'." (y-or-n-p (format "Save buffer %s first? " (buffer-name buff)))) ;; save BUFF. - (let ((old-buffer (current-buffer))) - (set-buffer buff) - (save-buffer) - (set-buffer old-buffer))))) + (with-current-buffer buff + (save-buffer))))) ;; (TERM-GET-SOURCE prompt prev-dir/file source-modes mustmatch-p) @@ -3453,8 +3439,7 @@ The top-most line is line 0." (defun term-display-buffer-line (buffer line) (let* ((window (display-buffer buffer t)) (pos)) - (save-excursion - (set-buffer buffer) + (with-current-buffer buffer (save-restriction (widen) (goto-char (point-min)) @@ -3896,8 +3881,7 @@ if KIND is 1, erase from home to point; else erase from home to point-max." (message "Output logging off.")) (if (get-buffer name) nil - (save-excursion - (set-buffer (get-buffer-create name)) + (with-current-buffer (get-buffer-create name) (fundamental-mode) (buffer-disable-undo (current-buffer)) (erase-buffer))) @@ -4169,8 +4153,7 @@ Typing SPC flushes the help buffer." (display-completion-list (sort completions 'string-lessp))) (message "Hit space to flush") (let (key first) - (if (save-excursion - (set-buffer (get-buffer "*Completions*")) + (if (with-current-buffer (get-buffer "*Completions*") (setq key (read-key-sequence nil) first (aref key 0)) (and (consp first) @@ -4197,8 +4180,7 @@ the process. Any more args are arguments to PROGRAM." ;; If no process, or nuked process, crank up a new one and put buffer in ;; term mode. Otherwise, leave buffer and existing process alone. (cond ((not (term-check-proc buffer)) - (save-excursion - (set-buffer buffer) + (with-current-buffer buffer (term-mode)) ; Install local vars, mode, keymap, ... (term-exec buffer name program startfile switches))) buffer)) @@ -4383,8 +4365,7 @@ use in that buffer. :coding 'no-conversion :noquery t)) (buffer (process-buffer process))) - (save-excursion - (set-buffer buffer) + (with-current-buffer buffer (term-mode) (term-char-mode) (goto-char (point-max)) |