aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Hansen2022-12-10 00:57:15 -0500
committerEli Zaretskii2022-12-31 10:48:37 +0200
commitf59d012af7e607448fdb435fcb4becb6a6ebe665 (patch)
tree021d328adcf28ef8afe9e952625ef35cb7b89893
parent24488bc4b275109d7132689a0714cfb11d05e512 (diff)
downloademacs-f59d012af7e607448fdb435fcb4becb6a6ebe665.tar.gz
emacs-f59d012af7e607448fdb435fcb4becb6a6ebe665.zip
whitespace: Use `define-globalized-minor-mode' for global mode
* lisp/whitespace.el (global-whitespace-mode): Fix interoperability between `whitespace-mode' and `global-whitespace-mode' by using `define-globalized-minor-mode'. (Bug#60334) * test/lisp/whitespace-tests.el (whitespace-tests--global): Add a regression test.
-rw-r--r--lisp/whitespace.el35
-rw-r--r--test/lisp/whitespace-tests.el18
2 files changed, 24 insertions, 29 deletions
diff --git a/lisp/whitespace.el b/lisp/whitespace.el
index 558be1841ab..7a30274a330 100644
--- a/lisp/whitespace.el
+++ b/lisp/whitespace.el
@@ -1014,34 +1014,11 @@ See also `whitespace-newline' and `whitespace-display-mappings'."
1014 1014
1015 1015
1016;;;###autoload 1016;;;###autoload
1017(define-minor-mode global-whitespace-mode 1017(define-globalized-minor-mode global-whitespace-mode
1018 "Toggle whitespace visualization globally (Global Whitespace mode). 1018 whitespace-mode
1019 1019 whitespace-turn-on-if-enabled
1020See also `whitespace-style', `whitespace-newline' and
1021`whitespace-display-mappings'."
1022 :lighter " WS"
1023 :init-value nil 1020 :init-value nil
1024 :global t 1021 :group 'whitespace)
1025 :group 'whitespace
1026 (cond
1027 (noninteractive ; running a batch job
1028 (setq global-whitespace-mode nil))
1029 (global-whitespace-mode ; global-whitespace-mode on
1030 (save-current-buffer
1031 (add-hook 'find-file-hook 'whitespace-turn-on-if-enabled)
1032 (add-hook 'after-change-major-mode-hook 'whitespace-turn-on-if-enabled)
1033 (dolist (buffer (buffer-list)) ; adjust all local mode
1034 (set-buffer buffer)
1035 (unless whitespace-mode
1036 (whitespace-turn-on-if-enabled)))))
1037 (t ; global-whitespace-mode off
1038 (save-current-buffer
1039 (remove-hook 'find-file-hook 'whitespace-turn-on-if-enabled)
1040 (remove-hook 'after-change-major-mode-hook 'whitespace-turn-on-if-enabled)
1041 (dolist (buffer (buffer-list)) ; adjust all local mode
1042 (set-buffer buffer)
1043 (unless whitespace-mode
1044 (whitespace-turn-off)))))))
1045 1022
1046(defvar whitespace-enable-predicate 1023(defvar whitespace-enable-predicate
1047 (lambda () 1024 (lambda ()
@@ -1067,7 +1044,7 @@ This variable is normally modified via `add-function'.")
1067 1044
1068(defun whitespace-turn-on-if-enabled () 1045(defun whitespace-turn-on-if-enabled ()
1069 (when (funcall whitespace-enable-predicate) 1046 (when (funcall whitespace-enable-predicate)
1070 (whitespace-turn-on))) 1047 (whitespace-mode)))
1071 1048
1072;;;###autoload 1049;;;###autoload
1073(define-minor-mode global-whitespace-newline-mode 1050(define-minor-mode global-whitespace-newline-mode
@@ -2511,7 +2488,7 @@ purposes)."
2511 (setq whitespace-display-table-was-local t) 2488 (setq whitespace-display-table-was-local t)
2512 ;; Save the old table so we can restore it when 2489 ;; Save the old table so we can restore it when
2513 ;; `whitespace-mode' is switched off again. 2490 ;; `whitespace-mode' is switched off again.
2514 (when (or whitespace-mode global-whitespace-mode) 2491 (when whitespace-mode
2515 (setq whitespace-display-table 2492 (setq whitespace-display-table
2516 (copy-sequence buffer-display-table))) 2493 (copy-sequence buffer-display-table)))
2517 ;; Assure `buffer-display-table' is unique 2494 ;; Assure `buffer-display-table' is unique
diff --git a/test/lisp/whitespace-tests.el b/test/lisp/whitespace-tests.el
index d72748cd0c9..3a53e025036 100644
--- a/test/lisp/whitespace-tests.el
+++ b/test/lisp/whitespace-tests.el
@@ -57,6 +57,24 @@ buffer's content."
57 (whitespace-cleanup) 57 (whitespace-cleanup)
58 (buffer-string))) 58 (buffer-string)))
59 59
60(ert-deftest whitespace-tests--global ()
61 (let ((backup global-whitespace-mode)
62 (noninteractive nil)
63 (whitespace-enable-predicate (lambda () t)))
64 (unwind-protect
65 (progn
66 (global-whitespace-mode 1)
67 (ert-with-test-buffer-selected ()
68 (normal-mode)
69 (should whitespace-mode)
70 (global-whitespace-mode -1)
71 (should (null whitespace-mode))
72 (whitespace-mode 1)
73 (should whitespace-mode)
74 (global-whitespace-mode 1)
75 (should whitespace-mode)))
76 (global-whitespace-mode (if backup 1 -1)))))
77
60(ert-deftest whitespace-cleanup-eob () 78(ert-deftest whitespace-cleanup-eob ()
61 (let ((whitespace-style '(empty))) 79 (let ((whitespace-style '(empty)))
62 (should (equal (whitespace-tests--cleanup-string "a\n") 80 (should (equal (whitespace-tests--cleanup-string "a\n")