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; -*-
|
||||
|
||||
(def-setting! :company-backend (modes backends)
|
||||
"Register company BACKENDS to MODES."
|
||||
(let ((backends (doom-enlist (doom-unquote backends))))
|
||||
(def-setting! :company-backend (modes &rest backends)
|
||||
"Prepends BACKENDS to `company-backends' in major MODES.
|
||||
|
||||
MODES should be one major-mode symbol or a list of them."
|
||||
`(progn
|
||||
,@(cl-loop for mode in (doom-enlist (doom-unquote modes))
|
||||
for def-name = (intern (format "doom--init-company-%s" mode))
|
||||
collect `(defun ,def-name ()
|
||||
(when (eq major-mode ',mode)
|
||||
(when (and (eq major-mode ',mode)
|
||||
,(not (eq backends '(nil))))
|
||||
(require 'company)
|
||||
(cl-pushnew ',backends company-backends :test #'equal)))
|
||||
collect `(add-hook! ,mode #',def-name)))))
|
||||
(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