2017-06-08 11:47:56 +02:00
|
|
|
;;; completion/company/autoload.el -*- lexical-binding: t; -*-
|
2017-02-19 18:41:26 -05:00
|
|
|
|
2018-07-29 21:31:58 +02:00
|
|
|
;;;###autoload
|
|
|
|
(defvar +company-backend-alist
|
2019-06-29 01:34:10 +02:00
|
|
|
'((text-mode company-dabbrev company-yasnippet company-ispell)
|
|
|
|
(prog-mode company-capf company-yasnippet)
|
|
|
|
(conf-mode company-capf company-dabbrev-code company-yasnippet))
|
2018-07-29 21:31:58 +02:00
|
|
|
"An alist matching modes to company backends. The backends for any mode is
|
|
|
|
built from this.")
|
|
|
|
|
2018-06-15 02:58:12 +02:00
|
|
|
;;;###autodef
|
|
|
|
(defun set-company-backend! (modes &rest backends)
|
2018-06-20 19:41:49 +02:00
|
|
|
"Prepends BACKENDS (in order) to `company-backends' in MODES.
|
2018-06-15 02:58:12 +02:00
|
|
|
|
2018-06-20 19:41:49 +02:00
|
|
|
MODES should be one symbol or a list of them, representing major or minor modes.
|
|
|
|
This will overwrite backends for MODES on consecutive uses.
|
|
|
|
|
2018-06-21 13:28:38 +02:00
|
|
|
If the car of BACKENDS is nil, unset the backends for MODES.
|
2018-06-20 19:41:49 +02:00
|
|
|
|
|
|
|
Examples:
|
|
|
|
|
2018-08-06 20:19:25 +02:00
|
|
|
(set-company-backend! 'js2-mode
|
|
|
|
'company-tide 'company-yasnippet)
|
|
|
|
|
2018-06-20 19:41:49 +02:00
|
|
|
(set-company-backend! 'sh-mode
|
|
|
|
'(company-shell :with company-yasnippet))
|
2018-08-06 20:19:25 +02:00
|
|
|
|
|
|
|
(set-company-backend! '(c-mode c++-mode)
|
2018-06-20 19:41:49 +02:00
|
|
|
'(:separate company-irony-c-headers company-irony))
|
2018-08-06 20:19:25 +02:00
|
|
|
|
2019-06-29 01:34:10 +02:00
|
|
|
(set-company-backend! 'sh-mode nil) ; unsets backends for sh-mode"
|
2018-06-22 01:30:27 +02:00
|
|
|
(declare (indent defun))
|
2019-06-29 01:34:10 +02:00
|
|
|
(dolist (mode (doom-enlist modes))
|
|
|
|
(if (null (car backends))
|
|
|
|
(setq +company-backend-alist
|
|
|
|
(delq (assq mode +company-backend-alist)
|
|
|
|
+company-backend-alist))
|
|
|
|
(setf (alist-get mode +company-backend-alist)
|
|
|
|
backends))))
|
2018-06-15 02:58:12 +02:00
|
|
|
|
2018-07-29 21:31:58 +02:00
|
|
|
|
|
|
|
;;
|
2019-04-17 11:19:22 -04:00
|
|
|
;;; Library
|
2018-07-29 21:31:58 +02:00
|
|
|
|
|
|
|
(defun +company--backends ()
|
2019-06-29 01:34:10 +02:00
|
|
|
(let (backends)
|
|
|
|
(let ((mode major-mode)
|
|
|
|
(modes (list major-mode)))
|
|
|
|
(while (setq mode (get mode 'derived-mode-parent))
|
|
|
|
(push mode modes))
|
|
|
|
(dolist (mode modes)
|
|
|
|
(dolist (backend (append (cdr (assq mode +company-backend-alist))
|
|
|
|
(default-value 'company-backends)))
|
|
|
|
(push backend backends)))
|
|
|
|
(delete-dups
|
|
|
|
(append (cl-loop for (mode . backends) in +company-backend-alist
|
|
|
|
if (or (eq major-mode mode) ; major modes
|
|
|
|
(and (boundp mode)
|
|
|
|
(symbol-value mode))) ; minor modes
|
|
|
|
append backends)
|
|
|
|
(nreverse backends))))))
|
2018-07-29 21:31:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
;;
|
2019-04-17 11:19:22 -04:00
|
|
|
;;; Hooks
|
2018-07-29 21:31:58 +02:00
|
|
|
|
|
|
|
;;;###autoload
|
2019-07-23 12:30:47 +02:00
|
|
|
(defun +company-init-backends-h ()
|
2018-07-29 21:31:58 +02:00
|
|
|
"Set `company-backends' for the current buffer."
|
2020-02-25 20:03:58 -05:00
|
|
|
(or (memq major-mode '(fundamental-mode special-mode))
|
|
|
|
buffer-read-only
|
|
|
|
(doom-temp-buffer-p (or (buffer-base-buffer) (current-buffer)))
|
|
|
|
(setq-local company-backends (+company--backends))))
|
2018-07-29 21:31:58 +02:00
|
|
|
|
2019-07-23 12:30:47 +02:00
|
|
|
(put '+company-init-backends-h 'permanent-local-hook t)
|
2018-07-29 21:31:58 +02:00
|
|
|
|
|
|
|
|
|
|
|
;;
|
2019-04-17 11:19:22 -04:00
|
|
|
;;; Commands
|
2018-07-29 21:31:58 +02:00
|
|
|
|
2018-12-23 23:57:29 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +company-has-completion-p ()
|
|
|
|
"Return non-nil if a completion candidate exists at point."
|
|
|
|
(and (company-manual-begin)
|
|
|
|
(= company-candidates-length 1)))
|
|
|
|
|
2018-06-01 14:53:49 +02:00
|
|
|
;;;###autoload
|
2018-02-02 15:57:38 -05:00
|
|
|
(defun +company/toggle-auto-completion ()
|
|
|
|
"Toggle as-you-type code completion."
|
|
|
|
(interactive)
|
|
|
|
(require 'company)
|
2018-05-31 15:59:52 +02:00
|
|
|
(setq company-idle-delay (unless company-idle-delay 0.2))
|
|
|
|
(message "Auto completion %s"
|
|
|
|
(if company-idle-delay "enabled" "disabled")))
|
2018-02-02 15:57:38 -05:00
|
|
|
|
2017-02-19 18:41:26 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +company/complete ()
|
|
|
|
"Bring up the completion popup. If only one result, complete it."
|
|
|
|
(interactive)
|
|
|
|
(require 'company)
|
2018-08-26 22:02:35 +02:00
|
|
|
(when (ignore-errors
|
|
|
|
(/= (point)
|
|
|
|
(cdr (bounds-of-thing-at-point 'symbol))))
|
2018-08-25 15:16:28 +02:00
|
|
|
(save-excursion (insert " ")))
|
2017-02-19 18:41:26 -05:00
|
|
|
(when (and (company-manual-begin)
|
|
|
|
(= company-candidates-length 1))
|
|
|
|
(company-complete-common)))
|
|
|
|
|
2018-05-28 00:08:14 +02:00
|
|
|
;;;###autoload
|
|
|
|
(defun +company/dabbrev ()
|
|
|
|
"Invokes `company-dabbrev-code' in prog-mode buffers and `company-dabbrev'
|
|
|
|
everywhere else."
|
|
|
|
(interactive)
|
|
|
|
(call-interactively
|
|
|
|
(if (derived-mode-p 'prog-mode)
|
|
|
|
#'company-dabbrev-code
|
|
|
|
#'company-dabbrev)))
|
|
|
|
|
2017-02-19 18:41:26 -05:00
|
|
|
;;;###autoload
|
|
|
|
(defun +company/whole-lines (command &optional arg &rest ignored)
|
|
|
|
"`company-mode' completion backend that completes whole-lines, akin to vim's
|
|
|
|
C-x C-l."
|
|
|
|
(interactive (list 'interactive))
|
|
|
|
(require 'company)
|
2017-06-08 11:47:56 +02:00
|
|
|
(pcase command
|
2018-05-08 17:57:26 +02:00
|
|
|
(`interactive (company-begin-backend '+company/whole-lines))
|
|
|
|
(`prefix (company-grab-line "^[\t\s]*\\(.+\\)" 1))
|
|
|
|
(`candidates
|
2017-06-08 11:47:56 +02:00
|
|
|
(all-completions
|
|
|
|
arg
|
2019-07-27 14:41:40 +07:00
|
|
|
(delete-dups
|
|
|
|
(split-string
|
|
|
|
(replace-regexp-in-string
|
|
|
|
"^[\t\s]+" ""
|
|
|
|
(concat (buffer-substring-no-properties (point-min) (line-beginning-position))
|
|
|
|
(buffer-substring-no-properties (line-end-position) (point-max))))
|
|
|
|
"\\(\r\n\\|[\n\r]\\)" t))))))
|
2017-02-19 18:41:26 -05:00
|
|
|
|
|
|
|
;;;###autoload
|
|
|
|
(defun +company/dict-or-keywords ()
|
|
|
|
"`company-mode' completion combining `company-dict' and `company-keywords'."
|
|
|
|
(interactive)
|
|
|
|
(require 'company-dict)
|
|
|
|
(require 'company-keywords)
|
|
|
|
(let ((company-backends '((company-keywords company-dict))))
|
2018-05-08 17:57:26 +02:00
|
|
|
(call-interactively #'company-complete)))
|
2017-02-19 18:41:26 -05:00
|
|
|
|
2017-06-09 00:36:38 +02:00
|
|
|
;;;###autoload
|
|
|
|
(defun +company/dabbrev-code-previous ()
|
2018-09-07 19:36:16 -04:00
|
|
|
"TODO"
|
2017-06-09 00:36:38 +02:00
|
|
|
(interactive)
|
|
|
|
(require 'company-dabbrev)
|
|
|
|
(let ((company-selection-wrap-around t))
|
2018-05-28 00:08:14 +02:00
|
|
|
(call-interactively #'+company/dabbrev)
|
2017-06-09 00:36:38 +02:00
|
|
|
(company-select-previous-or-abort)))
|