-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathhelm-describe-modes.el
184 lines (147 loc) · 6.51 KB
/
helm-describe-modes.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
;;; helm-describe-modes.el --- Helm interface to major and minor modes. -*- lexical-binding: t; -*-
;; Copyright (C) 2016 Tianxiang Xiong
;; Author: Tianxiang Xiong <[email protected]>
;; Package-Requires: ((helm "1.9") (cl-lib "0.5") (emacs "24.1"))
;; Keywords: docs, convenience
;; URL: https://github.com/emacs-helm/helm-describe-modes
;; Version: 1.0.0
;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;; GNU General Public License for more details.
;; You should have received a copy of the GNU General Public License
;; along with this program. If not, see <http://www.gnu.org/licenses/>.
;;; Commentary:
;; This package provides a Helm interface to major and minor mode
;; information. It is intended as a replacement for `describe-mode',
;; `describe-minor-mode', and other related commands.
;;
;; This package is heavily inspired by the `helm-descbinds' package by
;; Taiki Sugawara. See: https://github.com/emacs-helm/helm-descbinds
;;; Usage:
;; Add the following to your init file to remap `describe-mode' to
;; `helm-describe-modes':
;;
;; (require 'helm-describe-modes)
;; (global-set-key [remap describe-mode] #'helm-describe-modes)
;;
;; For information about the Helm framework, see the the Helm project:
;; https://github.com/emacs-helm/helm
;;; Code:
(require 'cl-lib)
(require 'helm)
(declare-function helm-elisp--persistent-help "helm-elisp")
;;; Customize
(defgroup helm-describe-modes nil
"Helm interface to major and minor mode information."
:prefix "helm-describe-modes-"
:group 'helm)
(defcustom helm-describe-modes-function-list
'(helm-describe-modes-def-source--major-mode
helm-describe-modes-def-source--active-minor-modes
helm-describe-modes-def-source--inactive-minor-modes)
"List of functions that build Helm sources for `helm-describe-modes'."
:group 'helm-describe-modes
:type '(repeat (choice symbol)))
(defcustom helm-describe-modes-major-mode-actions
'(("Describe major mode" . helm-describe-function)
("Find major mode" . helm-find-function)
("Customize major mode" . customize-mode)
("Set as initial major mode" . (lambda (mode)
(customize-set-variable 'initial-major-mode
mode))))
"Actions for major mode."
:group 'helm-describe-modes
:type '(alist :key-type string :value-type function))
(defcustom helm-describe-modes-active-minor-mode-actions
'(("Describe minor mode" . describe-minor-mode)
("Find minor mode" . helm-find-function)
("Turn off minor mode(s)" . (lambda (_ignored)
(mapc (lambda (mode)
(funcall (helm-describe-modes--minor-mode-function mode) -1)) (helm-marked-candidates)))))
"Actions for active minor modes."
:group 'helm-describe-modes
:type '(alist :key-type string :value-type function))
(defcustom helm-describe-modes-inactive-minor-mode-actions
'(("Describe minor mode" . describe-minor-mode)
("Find minor mode" . helm-find-function)
("Turn on minor mode(s)" . (lambda (_ignored)
(mapc (lambda (mode)
(funcall (helm-describe-modes--minor-mode-function mode) t))
(helm-marked-candidates)))))
"Actions for inactive minor modes."
:group 'helm-describe-modes
:type '(alist :key-type string :value-type function))
;;; Helm sources
(defun helm-describe-modes--minor-mode-function (minor-mode)
"Get the symbol for MINOR-MODE's function.
This is usually the same symbol as MINOR-MODE."
(or (get minor-mode :minor-mode-function)
minor-mode))
(defun helm-describe-modes--minor-modes ()
"Return a list of all minor modes symbols with functions.
Some older packages do not register in `minor-mode-list', only in
`minor-mode-alist'. See `describe-mode' for more information."
(cl-remove-if-not (lambda (mode)
(fboundp (helm-describe-modes--minor-mode-function mode)))
(cl-remove-duplicates (append (mapcar #'car minor-mode-alist)
minor-mode-list))))
(defun helm-describe-modes--active-minor-modes ()
"Return a list of active minor modes.
A minor mode is assumed to be active if it has a value."
(cl-remove-if-not (lambda (mode)
(and (boundp mode)
(symbol-value mode)))
(helm-describe-modes--minor-modes)))
(defun helm-describe-modes-def-source--major-mode ()
"Return a `helm' source for the major mode."
(helm-build-sync-source "Major mode"
:action 'helm-describe-modes-major-mode-actions
:candidates (list major-mode)
:coerce 'intern-soft
:nomark t))
(defun helm-describe-modes-def-source--active-minor-modes ()
"Return a `helm' source for active minor modes."
(helm-build-sync-source "Active minor modes"
:action 'helm-describe-modes-active-minor-mode-actions
:candidates (helm-describe-modes--active-minor-modes)
:candidate-transformer (lambda (modes)
(sort modes #'string-lessp))
:coerce 'intern-soft
:persistent-action (lambda (mode)
(helm-elisp--persistent-help
mode 'describe-minor-mode))
:persistent-help "Describe minor mode"))
(defun helm-describe-modes-def-source--inactive-minor-modes ()
"Return a `helm' source for inactive minor modes.
This is the set of all minor modes excluding active minor modes.
See `helm-describe-modes--minor-modes' and
`helm-describe-modes--active-minor-modes' for more information."
(helm-build-sync-source "Inactive minor modes"
:action 'helm-describe-modes-inactive-minor-mode-actions
:candidates (cl-set-difference (helm-describe-modes--minor-modes)
(helm-describe-modes--active-minor-modes))
:candidate-transformer (lambda (modes)
(sort modes #'string-lessp))
:coerce 'intern-soft
:persistent-action (lambda (mode)
(helm-elisp--persistent-help
mode 'describe-minor-mode))
:persistent-help "Describe minor mode"))
;;; Autoloads
;;;###autoload
(defun helm-describe-modes ()
"A convenient Helm version of `describe-mode'.
By default, it lists the major mode, active minor modes, and
inactive minor modes. Sources can be added or removed by
customizing `helm-describe-modes-function-list'."
(interactive)
(helm :sources (mapcar #'funcall helm-describe-modes-function-list)
:buffer "*Helm Describe Modes*"))
;;; Provide
(provide 'helm-describe-modes)
;;; helm-describe-modes.el ends here