my-emacs-d/elpa/helm-describe-modes-2016021.../helm-describe-modes.el

186 lines
6.5 KiB
EmacsLisp
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

;;; helm-describe-modes.el --- Helm interface to major and minor modes. -*- lexical-binding: t; -*-
;; Copyright (C) 2016 Tianxiang Xiong
;; Author: Tianxiang Xiong <tianxiang.xiong@gmail.com>
;; Package-Requires: ((helm "1.9") (cl-lib "0.5") (emacs "24.1"))
;; Package-Version: 20160211.2118
;; 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