2018-05-25 00:46:11 +02:00
|
|
|
;;; feature/lookup/autoload/docsets.el -*- lexical-binding: t; -*-
|
|
|
|
;;;###if (featurep! +docsets)
|
|
|
|
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
(defvar +lookup-docset-alist nil
|
|
|
|
"An alist mapping major and minor modes to lists of Dash docsets.
|
2018-06-15 21:37:36 +02:00
|
|
|
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
Entries are added by `set-docsets!' and used by `+lookup-docsets-for-buffer' to
|
|
|
|
assemble a list of installed & active docsets.")
|
2018-06-15 21:37:36 +02:00
|
|
|
|
2018-06-15 13:31:34 +02:00
|
|
|
;;;###autodef
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
(defun set-docsets! (modes &rest docsets)
|
2018-06-24 20:00:31 +02:00
|
|
|
"Registers a list of DOCSETS (strings) for MODES (either one major/minor mode
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
symbol or a list of them). DOCSETS can also contain sublists.
|
2018-06-15 13:31:34 +02:00
|
|
|
|
2018-06-24 20:00:31 +02:00
|
|
|
If MODES is a minor mode, you can use :add or :remove as the first element of
|
|
|
|
DOCSETS, to instruct it to append (or remove) those from the docsets already set
|
|
|
|
by a major-mode, if any.
|
|
|
|
|
2018-06-15 13:31:34 +02:00
|
|
|
Used by `+lookup/in-docsets' and `+lookup/documentation'."
|
2018-06-22 01:30:27 +02:00
|
|
|
(declare (indent defun))
|
2018-06-15 13:31:34 +02:00
|
|
|
(dolist (mode (doom-enlist modes))
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
(if (null docsets)
|
|
|
|
(setq +lookup-docset-alist
|
|
|
|
(delq (assq mode +lookup-docset-alist)
|
|
|
|
+lookup-docset-alist)))
|
|
|
|
(setf (alist-get mode +lookup-docset-alist)
|
|
|
|
(mapcan #'doom-enlist docsets))))
|
|
|
|
|
|
|
|
;;;###autodef
|
|
|
|
(defalias 'set-docset! #'set-docsets!)
|
2018-06-15 13:31:34 +02:00
|
|
|
|
2018-06-24 17:13:23 +02:00
|
|
|
;; FIXME obsolete :docset
|
2018-05-25 00:46:11 +02:00
|
|
|
;;;###autoload
|
|
|
|
(def-setting! :docset (modes &rest docsets)
|
2018-06-15 13:31:34 +02:00
|
|
|
:obsolete set-docset!
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
`(set-docsets! ,modes ,@docsets))
|
|
|
|
|
|
|
|
|
|
|
|
;;
|
|
|
|
;; Library
|
|
|
|
;;
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +lookup-docsets-for-buffer ()
|
|
|
|
"Return list of installed & selected docsets for the current major mode.
|
|
|
|
|
|
|
|
This list is built from `+lookup-docset-alist'."
|
|
|
|
(let ((base-docsets (cdr (assq major-mode +lookup-docset-alist))))
|
|
|
|
(dolist (spec +lookup-docset-alist)
|
|
|
|
(cl-destructuring-bind (mode . docsets) spec
|
|
|
|
(when (and (boundp mode) (symbol-value mode))
|
|
|
|
(pcase (car docsets)
|
|
|
|
(:add (nconc base-docsets (cdr docsets)))
|
|
|
|
(:remove
|
|
|
|
(dolist (docset (cdr docsets))
|
|
|
|
(setq base-docsets (delete docset base-docsets))))
|
|
|
|
(_ (setq base-docsets docsets))))))
|
|
|
|
base-docsets))
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +lookup-docset-installed-p (docset)
|
|
|
|
"Return t if DOCSET is installed."
|
|
|
|
(let ((path (helm-dash-docsets-path)))
|
|
|
|
(file-directory-p
|
|
|
|
(expand-file-name (format "%s.docset" docset)
|
|
|
|
path))))
|
2018-05-25 00:46:11 +02:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(autoload 'helm-dash-installed-docsets "helm-dash")
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(autoload 'helm-dash-docset-installed-p "helm-dash")
|
feature/lookup: rewrite dash docset integration
+ Uses alist variable to store config, rather than hooks
+ Added check for installed docsets in +lookup/documentation
+ Set docsets for various language modules (c-mode, c++-mode, css-mode,
scss-mode, sass-mode, web-mode, go-mode, racket-mode, emacs-lisp-mode,
js2-mode, rjsx-mode, typescript-mode, rust-mode, and php-mode)
+ Made *eww* popups for dash docsets larger
+ Renamed set-docset! => set-docsets! (set-docset! is aliased to
set-docsets!)
+ New +lookup/install-docset alias
2018-08-31 02:44:49 +02:00
|
|
|
|
|
|
|
|
|
|
|
;;
|
|
|
|
;; Commands
|
|
|
|
;;
|
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defalias '+lookup/install-docset #'helm-dash-install-docset)
|
|
|
|
|
|
|
|
(defvar counsel-dash-docsets)
|
|
|
|
(defvar helm-dash-docsets)
|
|
|
|
;;;###autoload
|
|
|
|
(defun +lookup/in-docsets (&optional query docsets)
|
|
|
|
"Lookup QUERY in dash DOCSETS.
|
|
|
|
|
|
|
|
QUERY is a string and docsets in an array of strings, each a name of a Dash
|
|
|
|
docset. Requires either helm or ivy.
|
|
|
|
|
|
|
|
Use `+lookup/install-docset' to install docsets."
|
|
|
|
(interactive)
|
|
|
|
(let* ((counsel-dash-docsets (or docsets (+lookup-docsets-for-buffer)))
|
|
|
|
(helm-dash-docsets counsel-dash-docsets)
|
|
|
|
(query (or query (+lookup--symbol-or-region) "")))
|
|
|
|
(cond ((featurep! :completion helm)
|
|
|
|
(helm-dash query))
|
|
|
|
((featurep! :completion ivy)
|
|
|
|
(counsel-dash query))
|
|
|
|
((user-error "No dash backend is installed, enable ivy or helm.")))))
|