diff options
| author | Richard Hansen | 2022-12-10 00:57:15 -0500 |
|---|---|---|
| committer | Eli Zaretskii | 2022-12-31 10:48:37 +0200 |
| commit | f59d012af7e607448fdb435fcb4becb6a6ebe665 (patch) | |
| tree | 021d328adcf28ef8afe9e952625ef35cb7b89893 | |
| parent | 24488bc4b275109d7132689a0714cfb11d05e512 (diff) | |
| download | emacs-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.el | 35 | ||||
| -rw-r--r-- | test/lisp/whitespace-tests.el | 18 |
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 | |
| 1020 | See 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") |