X-Git-Url: https://code.delx.au/gnu-emacs/blobdiff_plain/da5d3a563fc8c8f4adfa5031c2baa8236100c35f..8b9266575b536ee7e1f4eae6ea869513d77e0b74:/lisp/scroll-all.el diff --git a/lisp/scroll-all.el b/lisp/scroll-all.el index 734a83bace..f3bd3d334f 100644 --- a/lisp/scroll-all.el +++ b/lisp/scroll-all.el @@ -39,26 +39,6 @@ ;;; Code: -(defvar running-xemacs (string-match "XEmacs\\|Lucid" emacs-version)) - -;;;###autoload -(defcustom scroll-all-mode nil - "Control/track scroll locking. - -Setting this variable directly does not take effect; -use either \\[customize] or the function `scroll-all-mode'." - :set (lambda (symbol value) (scroll-all-mode (if value 1 0))) - :initialize 'custom-initialize-default - :require 'scroll-all - :type 'boolean - :group 'windows) - -(if running-xemacs - (add-minor-mode 'scroll-all-mode " *SL*") - (or (assq 'scroll-all-mode minor-mode-alist) - (setq minor-mode-alist - (cons '(scroll-all-mode " *SL*") minor-mode-alist)))) - (defun scroll-all-function-all (func arg) "Apply function FUNC with argument ARG to all visible windows." (let ((num-windows (count-windows)) @@ -119,18 +99,18 @@ use either \\[customize] or the function `scroll-all-mode'." (call-interactively 'scroll-all-beginning-of-buffer-all)) ((eq this-command 'end-of-buffer) (call-interactively 'scroll-all-end-of-buffer-all)))) - + ;;;###autoload -(defun scroll-all-mode (&optional arg) +(define-minor-mode scroll-all-mode "Toggle Scroll-All minor mode. With ARG, turn Scroll-All minor mode on if ARG is positive, off otherwise. When Scroll-All mode is on, scrolling commands entered in one window apply to all visible windows in the same frame." - (interactive "P") - (setq scroll-all-mode - (if (null arg) (not scroll-all-mode) - (> (prefix-numeric-value arg) 0))) + nil " *SL*" nil + :global t + :group 'windows + :group 'scrolling (if scroll-all-mode (add-hook 'post-command-hook 'scroll-all-check-to-scroll) (remove-hook 'post-command-hook 'scroll-all-check-to-scroll)))