From cae551977cab69d462ae589776f3e12833a41b6b Mon Sep 17 00:00:00 2001 From: Karl Heuer Date: Thu, 16 Oct 1997 18:20:16 +0000 Subject: [PATCH] Some changes in comments and documentation. View mode hooked into the customize tree. (view): New custom group. (view-highlight-face, view-scroll-auto-exit) (view-try-extend-at-buffer-end) (view-remove-frame-by-deleting, view-mode-hook): Defined by defcustom instead of by defvar. (view-mode-enter): Install exit-action also when view-mode is already on. Small rewrite using unless. (view-mode, view-mode-exit, view-scroll-lines, view-really-at-end) (view-search): Small rewrite using when or unless. --- lisp/view.el | 130 +++++++++++++++++++++++++++++++-------------------- 1 file changed, 79 insertions(+), 51 deletions(-) diff --git a/lisp/view.el b/lisp/view.el index 6c5b7446e17..8d7de369d20 100644 --- a/lisp/view.el +++ b/lisp/view.el @@ -30,7 +30,7 @@ ;; and view-mode-exit. Use these functions to enter or exit view-mode from ;; emacs lisp programs. ;; We use both view- and View- as prefix for symbols. View- is used as -;; prefix for commands that have a key binding. view- is used for commands +;; prefix for commands that have a key binding. view- is used for commands ;; without key binding. The purpose of this is to make it easier for a ;; user to use command name completion. @@ -44,45 +44,70 @@ ;;; Code: -;;;###autoload -(defvar view-highlight-face 'highlight - "*The face used for highlighting the match found by View mode search.") +(defgroup view nil + "Peruse file or buffer without editing." + :link '(function-link view-mode) + :link '(custom-manual "(emacs)Misc File Ops") + :group 'wp + :group 'editing) + +(defcustom view-read-only nil + "*Non-nil means buffers visiting files read-only, do it in view mode." + :type 'boolean + :group 'view) + +(defcustom view-highlight-face 'highlight + "*The face used for highlighting the match found by View mode search." + :type 'face + :group 'view) ;; `view-mode-auto-exit' is replaced by the following option variable which ;; only says if scrolling past buffer end should leave view mode or not, it ;; doesn't say if leaving view mode should restore windows or not. The latter ;; is now controlled by the presence of a value in `view-return-to-alist'. -;;;###autoload -(defvar view-scroll-auto-exit nil +(defcustom view-scroll-auto-exit nil "*Non-nil means scrolling past the end of buffer exits View mode. nil means attempting to scroll past the end of the buffer, -only rings the bell and gives a message on how to leave.") +only rings the bell and gives a message on how to leave." + :type 'boolean + :group 'view) -;;;###autoload -(defvar view-try-extend-at-buffer-end nil +(defcustom view-try-extend-at-buffer-end nil "*Non-nil means try load more of file when reaching end of buffer. This variable is mainly intended to be temporarily set to non-nil by the F command in view-mode, but you can set it to t if you want the action -for all scroll commands in view mode.") +for all scroll commands in view mode." + :type 'boolean + :group 'view) -(defvar view-remove-frame-by-deleting nil - "*Determine how to View mode removes a frame no longer needed. -If nil, make an icon of the frame. If non-nil, delete the frame.") +(defcustom view-remove-frame-by-deleting nil + "*Determine how View mode removes a frame no longer needed. +If nil, make an icon of the frame. If non-nil, delete the frame." + :type 'boolean + :group 'view) -;;;###autoload -(defvar view-exits-all-viewing-windows nil +(defcustom view-exits-all-viewing-windows nil "*Non-nil means restore all windows used to view buffer. Commands that restore windows when finished viewing a buffer, apply to all windows that display the buffer and have restore information in -`view-return-to-alist'.") +`view-return-to-alist'. +If view-exits-all-viewing-windows is nil only the selected window is +considered for restoring." + :type 'boolean + :group 'view) ;;;###autoload -(defvar view-mode nil "Non-nil if View mode is enabled.") +(defvar view-mode nil + "Non-nil if View mode is enabled. +Don't change this variable directly, you must change it by one of the +functions that enable or disable view mode.") ;;;###autoload (make-variable-buffer-local 'view-mode) -(defvar view-mode-hook nil - "Normal hook run when starting to view a buffer or file.") +(defcustom view-mode-hook nil + "Normal hook run when starting to view a buffer or file." + :type 'hook + :group 'view) (defvar view-old-buffer-read-only nil) (make-variable-buffer-local 'view-old-buffer-read-only) @@ -136,6 +161,7 @@ This is local in each buffer, once it is used.") (cons '(view-mode " View") minor-mode-alist))) ;; Define keymap inside defvar to make it easier to load changes. +;; Some redundant "less"-like key bindings below have been commented out. (defvar view-mode-map (let ((map (make-sparse-keymap))) (define-key map "C" 'View-kill-and-leave) @@ -398,12 +424,10 @@ to that buffer. Entry to view-mode runs the normal hook `view-mode-hook'." (interactive "P") - (cond - ((and arg - (if (> (prefix-numeric-value arg) 0) view-mode (not view-mode))) - ()) ; Do nothing if already OK. - (view-mode (view-mode-disable)) - (t (view-mode-enable)))) + (unless (and arg ; Do nothing if already OK. + (if (> (prefix-numeric-value arg) 0) view-mode (not view-mode))) + (if view-mode (view-mode-disable) + (view-mode-enable)))) (defun view-mode-enable () "Turn on View mode." @@ -459,10 +483,9 @@ This function runs the normal hook `view-mode-hook'." (let ((entry (assq (car return-to) view-return-to-alist))) (if entry (setcdr entry (cdr return-to)) (setq view-return-to-alist (cons return-to view-return-to-alist))))) - (if view-mode ; Do nothing if already in view mode. - nil + (if exit-action (setq view-exit-action exit-action)) + (unless view-mode ; Do nothing if already in view mode. (view-mode-enable) - (if exit-action (setq view-exit-action exit-action)) (force-mode-line-update) (message "%s" (substitute-command-keys "\ @@ -470,8 +493,7 @@ Type \\[help-command] for help, \\[describe-mode] for commands, \\[View-quit] to (defun view-mode-exit (&optional return-to-alist exit-action all-win) "Exit view-mode in various ways, depending on optional arguments. -RETURN-TO-ALIST, EXIT-ACTION and ALL-WIN determine what to do after -exit. +RETURN-TO-ALIST, EXIT-ACTION and ALL-WIN determine what to do after exit. EXIT-ACTION is nil or a function that is called with current buffer as argument. RETURN-TO-ALIST is an alist that for some of the windows displaying the @@ -538,10 +560,9 @@ corresponding OLD-WINDOW is a live window, then select OLD-WINDOW." (setq alist (cdr alist))) (if (window-live-p old-window) ; still existing window (select-window old-window)) -; (if (and exit-action (not (get-buffer-window buffer))) - (if exit-action - (progn (setq view-exit-action nil) - (funcall exit-action buffer))) + (when exit-action + (setq view-exit-action nil) + (funcall exit-action buffer)) (force-mode-line-update)))) (defun View-exit () @@ -672,8 +693,8 @@ Also set the mark at the position where point was." ;; window full. (if (or (null lines) (zerop (setq lines (prefix-numeric-value lines)))) (setq lines default)) - (if (< lines 0) - (progn (setq backward (not backward)) (setq lines (- lines)))) + (when (< lines 0) + (setq backward (not backward)) (setq lines (- lines))) (setq default (view-page-size-default nil)) ; Max scrolled at a time. (if maxdefault (setq lines (min lines default))) (cond @@ -697,20 +718,21 @@ Also set the mark at the position where point was." (let ((buf (current-buffer)) (bufname (buffer-name)) (file (buffer-file-name))) - (or (not view-try-extend-at-buffer-end) - (not file) - (verify-visited-file-modtime buf) - (not (file-exists-p file)) - (and (buffer-modified-p buf) - (setq file (file-name-nondirectory file)) - (not (yes-or-no-p - (format - "File %s changed on disk. Discard your edits%s? " - file - (if (string= bufname file) "" - (concat " in " bufname)))))) - (progn (revert-buffer t t t) - (pos-visible-in-window-p (point-max))))))) + (when (and view-try-extend-at-buffer-end + file + (not (verify-visited-file-modtime buf)) + (file-exists-p file) + (or (not (buffer-modified-p buf)) + (progn + (setq file (file-name-nondirectory file)) + (yes-or-no-p + (format + "File %s changed on disk. Discard your edits%s? " + file + (if (string= bufname file) "" + (concat " in " bufname))))))) + (revert-buffer t t t) + (pos-visible-in-window-p (point-max)))))) (defun view-end-message () ;; Tell that we are at end of buffer. @@ -872,6 +894,12 @@ for highlighting the match that is found." (defun view-search (times regexp) ;; This function does the job for all the View-search- commands. + ;; Search for the TIMESt match for REGEXP. If TIMES is negative + ;; search backwards. If REGEXP is nil use `view-last-regexp'. + ;; Charcters "!" and "@" have a special meaning at the beginning of + ;; REGEXP and are removed from REGEXP before the search "!" means + ;; search for lines with no match for REGEXP. "@" means search in + ;; the whole buffer, don't start searching from the present point. (let (where no end ln) (cond ((and regexp (> (length regexp) 0) @@ -885,7 +913,7 @@ for highlighting the match that is found." (setq view-last-regexp (if no (list regexp) regexp))) ((consp view-last-regexp) (setq regexp (car view-last-regexp)) - (if (not (setq no (not no))) (setq view-last-regexp regexp))) + (unless (setq no (not no)) (setq view-last-regexp regexp))) (view-last-regexp (setq regexp view-last-regexp) (if no (setq view-last-regexp (list regexp)))) (t (error "No previous View-mode search"))) -- 2.39.2