+ enable lexical-scope everywhere (lexical-binding = t): ~5-10% faster startup; ~5-20% general boost + reduce consing, function calls & garbage collection by preferring cl-loop & dolist over lambda closures (for mapc[ar], add-hook, and various cl-lib filter/map/reduce functions) -- where possible + prefer functions with dedicated opcodes, like assq (see byte-defop's in bytecomp.el for more) + prefer pcase & cond (faster) over cl-case + general refactor for code readability + ensure naming & style conventions are adhered to + appease byte-compiler by marking unused variables with underscore + defer minor mode activation to after-init, emacs-startup or window-setup hooks; a customization opportunity for users + ensures custom functionality won't interfere with startup.
85 lines
2.7 KiB
EmacsLisp
85 lines
2.7 KiB
EmacsLisp
;;; completion/company/config.el -*- lexical-binding: t; -*-
|
|
|
|
(def-setting! :company-backend (modes backends)
|
|
"Register company BACKENDS to MODES."
|
|
(let* ((modes (if (listp modes) modes (list modes)))
|
|
(backends (if (listp backends) backends (list backends)))
|
|
(def-name (intern (format "doom--init-company-%s"
|
|
(mapconcat #'identity (mapcar #'symbol-name modes) "-")))))
|
|
;; TODO more type checks
|
|
`(prog1
|
|
(defun ,def-name ()
|
|
(when (memq major-mode ',modes)
|
|
(require 'company)
|
|
(unless (member ',backends company-backends)
|
|
(setq-local company-backends (append '((,@backends)) company-backends)))))
|
|
(add-hook! ,modes #',def-name))))
|
|
|
|
|
|
;;
|
|
;; Packages
|
|
;;
|
|
|
|
(def-package! company
|
|
:commands (company-mode global-company-mode company-complete
|
|
company-complete-common company-manual-begin company-grab-line)
|
|
:config
|
|
(setq company-idle-delay nil
|
|
company-tooltip-limit 10
|
|
company-dabbrev-downcase nil
|
|
company-dabbrev-ignore-case nil
|
|
company-dabbrev-code-other-buffers t
|
|
company-tooltip-align-annotations t
|
|
company-require-match 'never
|
|
company-global-modes '(not eshell-mode comint-mode erc-mode message-mode help-mode)
|
|
company-frontends '(company-pseudo-tooltip-frontend company-echo-metadata-frontend)
|
|
company-backends '(company-capf))
|
|
|
|
(push #'company-sort-by-occurrence company-transformers)
|
|
|
|
(after! yasnippet
|
|
(nconc company-backends '(company-yasnippet)))
|
|
|
|
(global-company-mode +1))
|
|
|
|
|
|
(def-package! company-statistics
|
|
:after company
|
|
:config
|
|
(setq company-statistics-file (concat doom-cache-dir "company-stats-cache.el"))
|
|
(quiet! (company-statistics-mode +1)))
|
|
|
|
|
|
;; Looks ugly on OSX without emacs-mac build
|
|
(def-package! company-quickhelp
|
|
:after company
|
|
:config
|
|
(setq company-quickhelp-delay nil)
|
|
(company-quickhelp-mode +1))
|
|
|
|
|
|
(def-package! company-dict
|
|
:commands company-dict
|
|
:config
|
|
;; Project-specific dictionaries
|
|
(defun +company|enable-project-dicts (mode &rest _)
|
|
(if (symbol-value mode)
|
|
(push mode company-dict-minor-mode-list)
|
|
(setq company-dict-minor-mode-list (delq mode company-dict-minor-mode-list))))
|
|
(add-hook 'doom-project-hook #'+company|enable-project-dicts))
|
|
|
|
|
|
;;
|
|
;; Autoloads
|
|
;;
|
|
|
|
(autoload 'company-capf "company-capf")
|
|
(autoload 'company-yasnippet "company-yasnippet")
|
|
(autoload 'company-dabbrev "company-dabbrev")
|
|
(autoload 'company-dabbrev-code "company-dabbrev-code")
|
|
(autoload 'company-etags "company-etags")
|
|
(autoload 'company-elisp "company-elisp")
|
|
(autoload 'company-files "company-files")
|
|
(autoload 'company-gtags "company-gtags")
|
|
(autoload 'company-ispell "company-ispell")
|
|
|