Improve :company-backend setting according to #125
(set! :company-backend MODES &rest BACKENDS)
This commit is contained in:
parent
705d951af9
commit
a7dc91e7bf
1 changed files with 13 additions and 11 deletions
|
@ -1,16 +1,18 @@
|
||||||
;;; completion/company/config.el -*- lexical-binding: t; -*-
|
;;; completion/company/config.el -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
(def-setting! :company-backend (modes backends)
|
(def-setting! :company-backend (modes &rest backends)
|
||||||
"Register company BACKENDS to MODES."
|
"Prepends BACKENDS to `company-backends' in major MODES.
|
||||||
(let ((backends (doom-enlist (doom-unquote backends))))
|
|
||||||
`(progn
|
MODES should be one major-mode symbol or a list of them."
|
||||||
,@(cl-loop for mode in (doom-enlist (doom-unquote modes))
|
`(progn
|
||||||
for def-name = (intern (format "doom--init-company-%s" mode))
|
,@(cl-loop for mode in (doom-enlist (doom-unquote modes))
|
||||||
collect `(defun ,def-name ()
|
for def-name = (intern (format "doom--init-company-%s" mode))
|
||||||
(when (eq major-mode ',mode)
|
collect `(defun ,def-name ()
|
||||||
(require 'company)
|
(when (and (eq major-mode ',mode)
|
||||||
(cl-pushnew ',backends company-backends :test #'equal)))
|
,(not (eq backends '(nil))))
|
||||||
collect `(add-hook! ,mode #',def-name)))))
|
(require 'company)
|
||||||
|
(setq company-backends (append (list ,@backends) company-backends))))
|
||||||
|
collect `(add-hook! ,mode #',def-name))))
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue