Introduce autodefs to replace some settings
+ :popup -> set-popup-rule! + :popups -> set-popup-rules! + :company-backend -> set-company-backend! + :evil-state -> set-evil-initial-state! I am slowly phasing out the setting system (def-setting! and set!), starting with these. What are autodefs? These are functions that are always defined, whether or not their respective modules are enabled. However, when their modules are disabled, they are replaced with macros that no-op and don't waste time evaluating their arguments. The old set! function will still work, for a while.
This commit is contained in:
parent
6693db48af
commit
d8b1e469bc
54 changed files with 329 additions and 248 deletions
|
@ -357,7 +357,7 @@ omitted. eg. (featurep! +flag1)"
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
;; Cross-module configuration
|
;; Cross-module configuration (DEPRECATED)
|
||||||
;;
|
;;
|
||||||
|
|
||||||
;; I needed a way to reliably cross-configure modules without littering my
|
;; I needed a way to reliably cross-configure modules without littering my
|
||||||
|
@ -375,8 +375,16 @@ Do not use this for configuring Doom core."
|
||||||
(declare (indent defun) (doc-string 3))
|
(declare (indent defun) (doc-string 3))
|
||||||
(or (keywordp keyword)
|
(or (keywordp keyword)
|
||||||
(signal 'wrong-type-argument (list 'keywordp keyword)))
|
(signal 'wrong-type-argument (list 'keywordp keyword)))
|
||||||
`(fset ',(intern (format "doom--set%s" keyword))
|
(let ((alias (plist-get forms :obsolete)))
|
||||||
(lambda ,arglist ,docstring ,@forms)))
|
(when alias
|
||||||
|
(setq forms (plist-put forms :obsolete 'nil)))
|
||||||
|
`(fset ',(intern (format "doom--set%s" keyword))
|
||||||
|
(lambda ,arglist ,docstring
|
||||||
|
(prog1 (progn ,@forms)
|
||||||
|
,(when alias
|
||||||
|
`(unless noninteractive
|
||||||
|
(message ,(format "The `%s' setting is deprecated, use `%s' instead"
|
||||||
|
keyword alias)))))))))
|
||||||
|
|
||||||
(defmacro set! (keyword &rest values)
|
(defmacro set! (keyword &rest values)
|
||||||
"Set an option defined by `def-setting!'. Skip if doesn't exist. See
|
"Set an option defined by `def-setting!'. Skip if doesn't exist. See
|
||||||
|
|
|
@ -46,8 +46,11 @@ http://regexr.com/foo.html?q=bar
|
||||||
https://mediatemple.net"
|
https://mediatemple.net"
|
||||||
"TODO")
|
"TODO")
|
||||||
|
|
||||||
(set! :popup "^\\*doom-regex\\*$" '((size . 4)) '((quit)))
|
(set-popup-rules!
|
||||||
(set! :popup "^\\*doom-regex-groups"
|
'(("^\\*doom-regex\\*$"
|
||||||
'((side . left) (size . 28))
|
((size . 4))
|
||||||
'((select) (quit)))
|
((quit)))
|
||||||
|
("^\\*doom-regex-groups"
|
||||||
|
((side . left) (size . 28))
|
||||||
|
((select) (quit)))))
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@ absolute paths.")
|
||||||
elfeed-show-entry-delete #'+rss/delete-pane
|
elfeed-show-entry-delete #'+rss/delete-pane
|
||||||
shr-max-image-proportion 0.6)
|
shr-max-image-proportion 0.6)
|
||||||
|
|
||||||
(set! :popup "^\\*elfeed-entry"
|
(set-popup-rule! "^\\*elfeed-entry"
|
||||||
'((size . 0.75) (side . bottom))
|
'((size . 0.75) (side . bottom))
|
||||||
'((select . t) (quit) (transient . t)))
|
'((select . t) (quit) (transient . t)))
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
twittering-initial-timeline-spec-string
|
twittering-initial-timeline-spec-string
|
||||||
'(":home" ":mentions" ":direct_messages"))
|
'(":home" ":mentions" ":direct_messages"))
|
||||||
|
|
||||||
(set! :popup "^\\*twittering-edit"
|
(set-popup-rule! "^\\*twittering-edit"
|
||||||
'((size . 15))
|
'((size . 15))
|
||||||
'((transient) (quit) (select . t)))
|
'((transient) (quit) (select . t)))
|
||||||
|
|
||||||
|
|
|
@ -1,23 +1,30 @@
|
||||||
;;; completion/company/autoload.el -*- lexical-binding: t; -*-
|
;;; completion/company/autoload.el -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
|
;;;###autodef
|
||||||
|
(defun set-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."
|
||||||
|
(cl-loop for mode in modes
|
||||||
|
for def-name = (intern (format "doom--init-company-%s" mode))
|
||||||
|
do
|
||||||
|
(fset def-name
|
||||||
|
(lambda () (when (or (eq major-mode mode)
|
||||||
|
(and (boundp mode) (symbol-value mode)))
|
||||||
|
(require 'company)
|
||||||
|
(make-variable-buffer-local 'company-backends)
|
||||||
|
(dolist (backend backends)
|
||||||
|
(cl-pushnew backend company-backends :test #'equal)))))
|
||||||
|
and do (add-hook (intern (format "%s-hook" mode)) def-name)))
|
||||||
|
|
||||||
|
;; FIXME obsolete :company-backend
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(def-setting! :company-backend (modes &rest backends)
|
(def-setting! :company-backend (modes &rest backends)
|
||||||
"Prepends BACKENDS to `company-backends' in major MODES.
|
"Prepends BACKENDS to `company-backends' in major MODES.
|
||||||
|
|
||||||
MODES should be one major-mode symbol or a list of them."
|
MODES should be one major-mode symbol or a list of them."
|
||||||
`(progn
|
:obsolete set-company-backend!
|
||||||
,@(cl-loop for mode in (doom-enlist (doom-unquote modes))
|
`(set-company-backend! ,modes ,@backends))
|
||||||
for def-name = (intern (format "doom--init-company-%s" mode))
|
|
||||||
collect
|
|
||||||
`(defun ,def-name ()
|
|
||||||
(when (and (or (eq major-mode ',mode)
|
|
||||||
(bound-and-true-p ,mode))
|
|
||||||
,(not (eq backends '(nil))))
|
|
||||||
(require 'company)
|
|
||||||
(make-variable-buffer-local 'company-backends)
|
|
||||||
(dolist (backend (list ,@(reverse backends)))
|
|
||||||
(cl-pushnew backend company-backends :test #'equal))))
|
|
||||||
collect `(add-hook! ,mode #',def-name))))
|
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(defun +company/toggle-auto-completion ()
|
(defun +company/toggle-auto-completion ()
|
||||||
|
|
|
@ -117,7 +117,7 @@
|
||||||
;; `helm-ag'
|
;; `helm-ag'
|
||||||
(after! helm-ag
|
(after! helm-ag
|
||||||
(define-key helm-ag-edit-map [remap quit-window] #'helm-ag--edit-abort)
|
(define-key helm-ag-edit-map [remap quit-window] #'helm-ag--edit-abort)
|
||||||
(set! :popup "^\\*helm-ag-edit"
|
(set-popup-rule! "^\\*helm-ag-edit"
|
||||||
'((size . 0.35))
|
'((size . 0.35))
|
||||||
'((transient . 0) (quit))))
|
'((transient . 0) (quit))))
|
||||||
|
|
||||||
|
|
|
@ -86,7 +86,7 @@ immediately runs it on the current candidate (ending the ivy session)."
|
||||||
[remap swiper] #'counsel-grep-or-swiper)
|
[remap swiper] #'counsel-grep-or-swiper)
|
||||||
|
|
||||||
:config
|
:config
|
||||||
(set! :popup "^\\*ivy-occur" '((size . 0.35)) '((transient . 0) (quit)))
|
(set-popup-rule! "^\\*ivy-occur" '((size . 0.35)) '((transient . 0) (quit)))
|
||||||
|
|
||||||
(setq counsel-find-file-ignore-regexp "\\(?:^[#.]\\)\\|\\(?:[#~]$\\)\\|\\(?:^Icon?\\)"
|
(setq counsel-find-file-ignore-regexp "\\(?:^[#.]\\)\\|\\(?:[#~]$\\)\\|\\(?:^Icon?\\)"
|
||||||
;; Add smart-casing and compressed archive searching (-zS) to default
|
;; Add smart-casing and compressed archive searching (-zS) to default
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
(after! imenu-list
|
(after! imenu-list
|
||||||
(setq imenu-list-idle-update-delay 0.5)
|
(setq imenu-list-idle-update-delay 0.5)
|
||||||
|
|
||||||
(set! :popup "^\\*Ilist"
|
(set-popup-rule! "^\\*Ilist"
|
||||||
'((side . right) (size . 35))
|
'((side . right) (size . 35))
|
||||||
'((quit . current) (select) (transient . 0)))
|
'((quit . current) (select) (transient . 0)))
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
(def-package! realgud
|
(def-package! realgud
|
||||||
:commands (realgud:gdb realgud:trepanjs realgud:bashdb realgud:zshdb)
|
:commands (realgud:gdb realgud:trepanjs realgud:bashdb realgud:zshdb)
|
||||||
:config
|
:config
|
||||||
(set! :popup "^\\*\\(?trepanjs:\\(?:g\\|zsh\\|bash\\)db\\)"
|
(set-popup-rule! "^\\*\\(?trepanjs:\\(?:g\\|zsh\\|bash\\)db\\)"
|
||||||
'((size . 20)))
|
'((size . 20)))
|
||||||
|
|
||||||
;; TODO Temporary Ex commands for the debugger
|
;; TODO Temporary Ex commands for the debugger
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
:config
|
:config
|
||||||
(setq quickrun-focus-p nil)
|
(setq quickrun-focus-p nil)
|
||||||
|
|
||||||
(set! :popup "^\\*quickrun" '((size . 0.3)) '((transient . 0)))
|
(set-popup-rule! "^\\*quickrun" '((size . 0.3)) '((transient . 0)))
|
||||||
|
|
||||||
(defun +eval*quickrun-auto-close (&rest _)
|
(defun +eval*quickrun-auto-close (&rest _)
|
||||||
"Allows us to silently re-run quickrun from within the quickrun buffer."
|
"Allows us to silently re-run quickrun from within the quickrun buffer."
|
||||||
|
|
|
@ -1,15 +1,21 @@
|
||||||
;; feature/evil/autoload/evil.el -*- lexical-binding: t; -*-
|
;; feature/evil/autoload/evil.el -*- lexical-binding: t; -*-
|
||||||
;;;###if (featurep! :feature evil)
|
;;;###if (featurep! :feature evil)
|
||||||
|
|
||||||
|
;;;###autodef
|
||||||
|
(defun set-evil-initial-state! (modes state)
|
||||||
|
"Set the initialize STATE of MODE using `evil-set-initial-state'."
|
||||||
|
(after! evil
|
||||||
|
(if (listp modes)
|
||||||
|
(dolist (mode modes)
|
||||||
|
(evil-set-initial-state mode state))
|
||||||
|
(evil-set-initial-state modes state))))
|
||||||
|
|
||||||
|
;; FIXME obsolete :evil-state
|
||||||
;;;###autoload
|
;;;###autoload
|
||||||
(def-setting! :evil-state (modes state)
|
(def-setting! :evil-state (modes state)
|
||||||
"Set the initialize STATE of MODE using `evil-set-initial-state'."
|
"Set the initialize STATE of MODE using `evil-set-initial-state'."
|
||||||
(let ((unquoted-modes (doom-unquote modes)))
|
:obsolete set-evil-initial-state!
|
||||||
(if (listp unquoted-modes)
|
`(set-evil-initial-state! ,modes ,state))
|
||||||
`(progn
|
|
||||||
,@(cl-loop for mode in unquoted-modes
|
|
||||||
collect `(evil-set-initial-state ',mode ,state)))
|
|
||||||
`(evil-set-initial-state ,modes ,state))))
|
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -66,8 +66,9 @@ variable for an explanation of the defaults (in comments). See
|
||||||
|
|
||||||
(put 'evil-define-key* 'lisp-indent-function 'defun)
|
(put 'evil-define-key* 'lisp-indent-function 'defun)
|
||||||
|
|
||||||
(set! :popup "^\\*evil-registers" '((size . 0.3)))
|
(set-popup-rules!
|
||||||
(set! :popup "^\\*Command Line" '((size . 8)))
|
'(("^\\*evil-registers" ((size . 0.3)))
|
||||||
|
("^\\*Command Line" ((size . 8)))))
|
||||||
|
|
||||||
;; Change the cursor color in emacs mode
|
;; Change the cursor color in emacs mode
|
||||||
(defvar +evil--default-cursor-color "#ffffff")
|
(defvar +evil--default-cursor-color "#ffffff")
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
;;; feature/file-templates/autoload.el -*- lexical-binding: t; -*-
|
;;; feature/file-templates/autoload.el -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autodef
|
||||||
(def-setting! :file-template (pred &rest plist)
|
(defun set-file-template! (pred &rest plist)
|
||||||
"Register a file template.
|
"Register a file template.
|
||||||
|
|
||||||
PRED can either be a regexp string or a major mode symbol. PLIST may contain
|
PRED can either be a regexp string or a major mode symbol. PLIST may contain
|
||||||
|
@ -24,11 +24,23 @@ these properties:
|
||||||
file template rule against this buffer."
|
file template rule against this buffer."
|
||||||
`(push (list ,pred ,@plist) +file-templates-alist))
|
`(push (list ,pred ,@plist) +file-templates-alist))
|
||||||
|
|
||||||
;;;###autoload
|
;;;###autodef
|
||||||
(def-setting! :file-templates (&rest templates)
|
(defun set-file-templates! (&rest templates)
|
||||||
"Like `doom--set:file-template', but register many file templates at once."
|
"Like `doom--set:file-template', but register many file templates at once."
|
||||||
`(setq +file-templates-alist (append (list ,@templates) +file-templates-alist)))
|
`(setq +file-templates-alist (append (list ,@templates) +file-templates-alist)))
|
||||||
|
|
||||||
|
;; FIXME obsolete :file-template
|
||||||
|
;;;###autoload
|
||||||
|
(def-setting! :file-template (pred &rest plist)
|
||||||
|
:obsolete set-file-template!
|
||||||
|
`(set-file-template! ,pred ,@plist))
|
||||||
|
|
||||||
|
;; FIXME obsolete :file-templates
|
||||||
|
;;;###autoload
|
||||||
|
(def-setting! :file-templates (&rest templates)
|
||||||
|
:obsolete set-file-templates!
|
||||||
|
`(set-file-templates! ,@templates))
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
;; Library
|
;; Library
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
(git-gutter-mode +1)))
|
(git-gutter-mode +1)))
|
||||||
(add-hook! (text-mode prog-mode conf-mode) #'+version-control|git-gutter-maybe)
|
(add-hook! (text-mode prog-mode conf-mode) #'+version-control|git-gutter-maybe)
|
||||||
:config
|
:config
|
||||||
(set! :popup "^\\*git-gutter" nil '((select)))
|
(set-popup-rule! "^\\*git-gutter" nil '((select)))
|
||||||
|
|
||||||
;; Update git-gutter on focus (in case I was using git externally)
|
;; Update git-gutter on focus (in case I was using git externally)
|
||||||
(add-hook 'focus-in-hook #'git-gutter:update-all-windows)
|
(add-hook 'focus-in-hook #'git-gutter:update-all-windows)
|
||||||
|
|
|
@ -11,11 +11,12 @@
|
||||||
|
|
||||||
|
|
||||||
(after! vc-annotate
|
(after! vc-annotate
|
||||||
(set! :popup "^\\vc-d" nil '((select))) ; *vc-diff*
|
(set-popup-rules!
|
||||||
(set! :popup "^\\vc-c" nil '((select . t))) ; *vc-change-log*
|
'(("^\\vc-d" nil ((select))) ; *vc-diff*
|
||||||
|
("^\\vc-c" nil ((select . t))))) ; *vc-change-log*
|
||||||
(set! :evil-state 'vc-annotate-mode 'normal)
|
(set-evil-initial-state!
|
||||||
(set! :evil-state 'vc-git-log-view-mode 'normal))
|
'(vc-annotate-mode vc-git-log-view-mode)
|
||||||
|
'normal))
|
||||||
|
|
||||||
(def-package! smerge-mode
|
(def-package! smerge-mode
|
||||||
:hook (find-file . +vcs|enable-smerge-mode-maybe)
|
:hook (find-file . +vcs|enable-smerge-mode-maybe)
|
||||||
|
|
|
@ -156,7 +156,7 @@ compilation database is present in the project.")
|
||||||
(def-package! company-irony
|
(def-package! company-irony
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:init
|
:init
|
||||||
(set! :company-backend
|
(set-company-backend!
|
||||||
'(c-mode c++-mode objc-mode)
|
'(c-mode c++-mode objc-mode)
|
||||||
'(:separate company-irony-c-headers company-irony))
|
'(:separate company-irony-c-headers company-irony))
|
||||||
:config
|
:config
|
||||||
|
@ -168,7 +168,8 @@ compilation database is present in the project.")
|
||||||
;;
|
;;
|
||||||
|
|
||||||
;; `cmake-mode'
|
;; `cmake-mode'
|
||||||
(set! :company-backend 'cmake-mode '(company-cmake company-yasnippet))
|
(after! cmake-mode
|
||||||
|
(set-company-backend! 'cmake-mode '(company-cmake company-yasnippet)))
|
||||||
|
|
||||||
(def-package! company-cmake
|
(def-package! company-cmake
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
|
@ -183,7 +184,7 @@ compilation database is present in the project.")
|
||||||
(def-package! company-glsl
|
(def-package! company-glsl
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after glsl-mode
|
:after glsl-mode
|
||||||
:config (set! :company-backend 'glsl-mode '(company-glsl)))
|
:config (set-company-backend! 'glsl-mode '(company-glsl)))
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
(figwheel-sidecar.repl-api/start-figwheel!)
|
(figwheel-sidecar.repl-api/start-figwheel!)
|
||||||
(figwheel-sidecar.repl-api/cljs-repl))")
|
(figwheel-sidecar.repl-api/cljs-repl))")
|
||||||
|
|
||||||
(set! :popup "^\\*cider-repl" nil '((quit) (select)))
|
(set-popup-rule! "^\\*cider-repl" nil '((quit) (select)))
|
||||||
(set! :repl 'clojure-mode #'+clojure/repl)
|
(set! :repl 'clojure-mode #'+clojure/repl)
|
||||||
(set! :eval 'clojure-mode #'cider-eval-region)
|
(set! :eval 'clojure-mode #'cider-eval-region)
|
||||||
(set! :lookup 'clojure-mode
|
(set! :lookup 'clojure-mode
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
(omnisharp-stop-server)))
|
(omnisharp-stop-server)))
|
||||||
(add-hook! csharp-mode (add-hook 'kill-buffer-hook #'omnisharp-stop-server nil t))
|
(add-hook! csharp-mode (add-hook 'kill-buffer-hook #'omnisharp-stop-server nil t))
|
||||||
|
|
||||||
(set! :company-backend 'csharp-mode '(company-omnisharp))
|
(set-company-backend! 'csharp-mode '(company-omnisharp))
|
||||||
|
|
||||||
(set! :lookup 'csharp-mode
|
(set! :lookup 'csharp-mode
|
||||||
:definition #'omnisharp-go-to-definition
|
:definition #'omnisharp-go-to-definition
|
||||||
|
|
|
@ -6,7 +6,8 @@
|
||||||
("\\.plist\\'" . nxml-mode)))
|
("\\.plist\\'" . nxml-mode)))
|
||||||
(map-put auto-mode-alist (car spec) (cdr spec)))
|
(map-put auto-mode-alist (car spec) (cdr spec)))
|
||||||
|
|
||||||
(set! :company-backend 'nxml-mode '(company-nxml company-yasnippet))
|
(after! nxml-mode
|
||||||
|
(set-company-backend! 'nxml-mode '(company-nxml company-yasnippet)))
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -12,7 +12,19 @@
|
||||||
:skip-match 'sp-elixir-skip-def-p
|
:skip-match 'sp-elixir-skip-def-p
|
||||||
:post-handlers '("||\n[i]"))
|
:post-handlers '("||\n[i]"))
|
||||||
(sp-local-pair "do " " end" :unless '(sp-in-comment-p sp-in-string-p))
|
(sp-local-pair "do " " end" :unless '(sp-in-comment-p sp-in-string-p))
|
||||||
(sp-local-pair "fn " " end" :unless '(sp-in-comment-p sp-in-string-p)))))
|
(sp-local-pair "fn " " end" :unless '(sp-in-comment-p sp-in-string-p))))
|
||||||
|
|
||||||
|
(def-package! alchemist-company
|
||||||
|
:when (featurep! :completion company)
|
||||||
|
:commands alchemist-company
|
||||||
|
:init
|
||||||
|
(set-company-backend! 'elixir-mode '(alchemist-company company-yasnippet))
|
||||||
|
:config
|
||||||
|
;; Alchemist doesn't use hook symbols to add these backends, so we have to use
|
||||||
|
;; the entire closure to get rid of it.
|
||||||
|
(let ((fn (byte-compile (lambda () (add-to-list (make-local-variable 'company-backends) 'alchemist-company)))))
|
||||||
|
(remove-hook 'alchemist-mode-hook fn)
|
||||||
|
(remove-hook 'alchemist-iex-mode-hook fn))))
|
||||||
|
|
||||||
|
|
||||||
(def-package! alchemist
|
(def-package! alchemist
|
||||||
|
@ -24,16 +36,3 @@
|
||||||
(set! :eval 'elixir-mode #'alchemist-eval-region)
|
(set! :eval 'elixir-mode #'alchemist-eval-region)
|
||||||
(set! :repl 'elixir-mode #'alchemist-iex-project-run))
|
(set! :repl 'elixir-mode #'alchemist-iex-project-run))
|
||||||
|
|
||||||
|
|
||||||
(def-package! alchemist-company
|
|
||||||
:when (featurep! :completion company)
|
|
||||||
:commands alchemist-company
|
|
||||||
:init
|
|
||||||
(set! :company-backend 'elixir-mode '(alchemist-company company-yasnippet))
|
|
||||||
:config
|
|
||||||
;; Alchemist doesn't use hook symbols to add these backends, so we have to use
|
|
||||||
;; the entire closure to get rid of it.
|
|
||||||
(let ((fn (byte-compile (lambda () (add-to-list (make-local-variable 'company-backends) 'alchemist-company)))))
|
|
||||||
(remove-hook 'alchemist-mode-hook fn)
|
|
||||||
(remove-hook 'alchemist-iex-mode-hook fn)))
|
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
|
|
||||||
(after! elm-mode
|
(after! elm-mode
|
||||||
(add-hook! 'elm-mode-hook #'(flycheck-mode rainbow-delimiters-mode))
|
(add-hook! 'elm-mode-hook #'(flycheck-mode rainbow-delimiters-mode))
|
||||||
(set! :company-backend 'elm-mode 'company-elm)
|
(set-company-backend! 'elm-mode 'company-elm)
|
||||||
(set! :repl 'elm-mode #'run-elm-interactive))
|
(set! :repl 'elm-mode #'run-elm-interactive))
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -78,5 +78,5 @@
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after go-mode
|
:after go-mode
|
||||||
:config
|
:config
|
||||||
(set! :company-backend 'go-mode 'company-go)
|
(set-company-backend! 'go-mode 'company-go)
|
||||||
(setq company-go-show-annotation t))
|
(setq company-go-show-annotation t))
|
||||||
|
|
|
@ -16,4 +16,4 @@
|
||||||
(add-hook 'haskell-mode-hook #'ghc-comp-init)
|
(add-hook 'haskell-mode-hook #'ghc-comp-init)
|
||||||
:config
|
:config
|
||||||
(setq company-ghc-show-info 'oneline)
|
(setq company-ghc-show-info 'oneline)
|
||||||
(set! :company-backend 'haskell-mode #'company-ghc))
|
(set-company-backend! 'haskell-mode #'company-ghc))
|
||||||
|
|
|
@ -5,4 +5,4 @@
|
||||||
:interpreter "hy"
|
:interpreter "hy"
|
||||||
:config
|
:config
|
||||||
(set! :repl 'hy-mode #'hy-shell-start-or-switch-to-shell)
|
(set! :repl 'hy-mode #'hy-shell-start-or-switch-to-shell)
|
||||||
(set! :company-backend 'hy-mode 'company-hy))
|
(set-company-backend! 'hy-mode 'company-hy))
|
||||||
|
|
|
@ -55,4 +55,4 @@
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after java-mode
|
:after java-mode
|
||||||
:config
|
:config
|
||||||
(set! :company-backend 'java-mode '(company-emacs-eclim)))
|
(set-company-backend! 'java-mode '(company-emacs-eclim)))
|
||||||
|
|
|
@ -94,7 +94,7 @@
|
||||||
;; tide affects the global `company-backends', undo this so doom can handle
|
;; tide affects the global `company-backends', undo this so doom can handle
|
||||||
;; it buffer-locally
|
;; it buffer-locally
|
||||||
(setq-default company-backends (delq 'company-tide (default-value 'company-backends))))
|
(setq-default company-backends (delq 'company-tide (default-value 'company-backends))))
|
||||||
(set! :company-backend 'tide-mode 'company-tide)
|
(set-company-backend! 'tide-mode 'company-tide)
|
||||||
|
|
||||||
;; navigation
|
;; navigation
|
||||||
(set! :lookup 'tide-mode
|
(set! :lookup 'tide-mode
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
font-latex-fontify-sectioning 1.15)
|
font-latex-fontify-sectioning 1.15)
|
||||||
(setq-default TeX-master nil)
|
(setq-default TeX-master nil)
|
||||||
;; Display the output of the latex commands in a popup.
|
;; Display the output of the latex commands in a popup.
|
||||||
(set! :popup " output\\*$" '((size . 15)))
|
(set-popup-rule! " output\\*$" '((size . 15)))
|
||||||
|
|
||||||
;; TeX Font Styling
|
;; TeX Font Styling
|
||||||
;; (def-package! tex-style :defer t)
|
;; (def-package! tex-style :defer t)
|
||||||
|
@ -200,7 +200,7 @@
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:commands (company-auctex-init)
|
:commands (company-auctex-init)
|
||||||
:init
|
:init
|
||||||
;; We can't use the (set! :company-backend ...) because Auctex reports its
|
;; We can't use the (set-company-backend! ...) because Auctex reports its
|
||||||
;; major-mode as `latex-mode', but uses LaTeX-mode-hook for its mode, which is
|
;; major-mode as `latex-mode', but uses LaTeX-mode-hook for its mode, which is
|
||||||
;; not anticipated by :company-backend (and shouldn't have to!)
|
;; not anticipated by :company-backend (and shouldn't have to!)
|
||||||
(add-hook! LaTeX-mode
|
(add-hook! LaTeX-mode
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
(set! :lookup 'lua-mode :documentation 'lua-search-documentation)
|
(set! :lookup 'lua-mode :documentation 'lua-search-documentation)
|
||||||
(set! :electric 'lua-mode :words '("else" "end"))
|
(set! :electric 'lua-mode :words '("else" "end"))
|
||||||
(set! :repl 'lua-mode #'+lua/repl)
|
(set! :repl 'lua-mode #'+lua/repl)
|
||||||
(set! :company-backend 'lua-mode '(company-lua company-yasnippet))
|
(set-company-backend! 'lua-mode '(company-lua company-yasnippet))
|
||||||
|
|
||||||
(def-menu! +lua/build-menu
|
(def-menu! +lua/build-menu
|
||||||
"Build/compilation commands for `lua-mode' buffers."
|
"Build/compilation commands for `lua-mode' buffers."
|
||||||
|
|
|
@ -8,6 +8,6 @@
|
||||||
:after tuareg
|
:after tuareg
|
||||||
:hook (tuareg-mode . merlin-mode)
|
:hook (tuareg-mode . merlin-mode)
|
||||||
:config
|
:config
|
||||||
(set! :company-backend 'tuareg-mode 'merlin-company-backend)
|
(set-company-backend! 'tuareg-mode 'merlin-company-backend)
|
||||||
(after! company
|
(after! company
|
||||||
(remove-hook 'company-backends 'merlin-company-backend)))
|
(remove-hook 'company-backends 'merlin-company-backend)))
|
||||||
|
|
|
@ -71,19 +71,19 @@ string). Stops at the first function to return non-nil.")
|
||||||
(require 'ob-ipython nil t)))
|
(require 'ob-ipython nil t)))
|
||||||
(add-hook '+org-babel-load-functions #'+org|babel-load-ipython)
|
(add-hook '+org-babel-load-functions #'+org|babel-load-ipython)
|
||||||
:config
|
:config
|
||||||
(set! :popups
|
(set-popup-rules!
|
||||||
'("^\\*Org Src"
|
'(("^\\*Org Src"
|
||||||
((size . 100) (side . right) (slot . -1) (window-height . 0.6))
|
((size . 100) (side . right) (slot . -1) (window-height . 0.6))
|
||||||
((quit) (select . t) (modeline)))
|
((quit) (select . t) (modeline)))
|
||||||
'("^\\*Python"
|
("^\\*Python"
|
||||||
((slot . 0) (side . right) (size . 100))
|
((slot . 0) (side . right) (size . 100))
|
||||||
((select) (quit) (transient)))
|
((select) (quit) (transient)))
|
||||||
'("\\*ob-ipython.*"
|
("\\*ob-ipython.*"
|
||||||
((slot . 2) (side . right) (size . 100) (window-height . 0.2))
|
((slot . 2) (side . right) (size . 100) (window-height . 0.2))
|
||||||
((select) (quit) (transient)))
|
((select) (quit) (transient)))
|
||||||
'("\\*Python:.*"
|
("\\*Python:.*"
|
||||||
((slot . 0) (side . right) (size . 100))
|
((slot . 0) (side . right) (size . 100))
|
||||||
((select) (quit) (transient))))
|
((select) (quit) (transient)))))
|
||||||
;; TODO Add more popup styles
|
;; TODO Add more popup styles
|
||||||
|
|
||||||
;; advices for remote kernel and org-src-edit
|
;; advices for remote kernel and org-src-edit
|
||||||
|
|
|
@ -137,19 +137,19 @@ unfold to point on startup."
|
||||||
|
|
||||||
(defun +org|setup-popups-rules ()
|
(defun +org|setup-popups-rules ()
|
||||||
"Defines popup rules for org-mode (does nothing if :ui popup is disabled)."
|
"Defines popup rules for org-mode (does nothing if :ui popup is disabled)."
|
||||||
(set! :popups
|
(set-popup-rules!
|
||||||
'("^\\*\\(?:Agenda Com\\|Calendar\\|Org \\(?:Links\\|Export Dispatcher\\|Select\\)\\)"
|
'(("^\\*\\(?:Agenda Com\\|Calendar\\|Org \\(?:Links\\|Export Dispatcher\\|Select\\)\\)"
|
||||||
((slot . -1) (vslot . -1) (size . +popup-shrink-to-fit))
|
((slot . -1) (vslot . -1) (size . +popup-shrink-to-fit))
|
||||||
((transient . 0)))
|
((transient . 0)))
|
||||||
'("^\\*Org Agenda"
|
("^\\*Org Agenda"
|
||||||
((size . 0.35))
|
((size . 0.35))
|
||||||
((select . t) (transient)))
|
((select . t) (transient)))
|
||||||
'("^\\*Org Src"
|
("^\\*Org Src"
|
||||||
((size . 0.3))
|
((size . 0.3))
|
||||||
((quit) (select . t)))
|
((quit) (select . t)))
|
||||||
'("^CAPTURE.*\\.org$"
|
("^CAPTURE.*\\.org$"
|
||||||
((size . 0.2))
|
((size . 0.2))
|
||||||
((quit) (select . t)))))
|
((quit) (select . t))))))
|
||||||
|
|
||||||
(defun +org|setup-ui ()
|
(defun +org|setup-ui ()
|
||||||
"Configures the UI for `org-mode'."
|
"Configures the UI for `org-mode'."
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
;; (def-package! hack-mode
|
;; (def-package! hack-mode
|
||||||
;; :mode "\\.hh$"
|
;; :mode "\\.hh$"
|
||||||
;; :config
|
;; :config
|
||||||
;; (set! :company-backend 'hack-mode '(company-capf)))
|
;; (set-company-backend! 'hack-mode '(company-capf)))
|
||||||
|
|
||||||
|
|
||||||
(def-package! php-mode
|
(def-package! php-mode
|
||||||
|
@ -22,7 +22,7 @@
|
||||||
|
|
||||||
;; ac-php provides custom autocompletion, php-extras provides autocompletion
|
;; ac-php provides custom autocompletion, php-extras provides autocompletion
|
||||||
;; for built-in libraries
|
;; for built-in libraries
|
||||||
(set! :company-backend 'php-mode '(company-ac-php-backend php-extras-company))
|
(set-company-backend! 'php-mode '(company-ac-php-backend php-extras-company))
|
||||||
|
|
||||||
;; default is 10; this optimizes `smartparens' performance, but limits sp
|
;; default is 10; this optimizes `smartparens' performance, but limits sp
|
||||||
;; pairs to 6 characters.
|
;; pairs to 6 characters.
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
(setq plantuml-jar-path (concat doom-etc-dir "plantuml.jar")
|
(setq plantuml-jar-path (concat doom-etc-dir "plantuml.jar")
|
||||||
org-plantuml-jar-path plantuml-jar-path)
|
org-plantuml-jar-path plantuml-jar-path)
|
||||||
:config
|
:config
|
||||||
(set! :popup "^\\*PLANTUML" '((size . 0.4)) '((select) (transient . 0))))
|
(set-popup-rule! "^\\*PLANTUML" '((size . 0.4)) '((select) (transient . 0))))
|
||||||
|
|
||||||
|
|
||||||
(def-package! flycheck-plantuml
|
(def-package! flycheck-plantuml
|
||||||
|
|
|
@ -79,8 +79,8 @@ environment variables."
|
||||||
:config
|
:config
|
||||||
(add-hook 'python-mode-hook #'anaconda-mode)
|
(add-hook 'python-mode-hook #'anaconda-mode)
|
||||||
(add-hook 'anaconda-mode-hook #'anaconda-eldoc-mode)
|
(add-hook 'anaconda-mode-hook #'anaconda-eldoc-mode)
|
||||||
(set! :company-backend 'python-mode '(company-anaconda))
|
(set-company-backend! 'python-mode '(company-anaconda))
|
||||||
(set! :popup "^\\*anaconda-mode" nil '((select)))
|
(set-popup-rule! "^\\*anaconda-mode" nil '((select)))
|
||||||
(set! :lookup 'python-mode
|
(set! :lookup 'python-mode
|
||||||
:definition #'anaconda-mode-find-definitions
|
:definition #'anaconda-mode-find-definitions
|
||||||
:references #'anaconda-mode-find-references
|
:references #'anaconda-mode-find-references
|
||||||
|
@ -112,7 +112,7 @@ environment variables."
|
||||||
:init
|
:init
|
||||||
(associate! nose-mode :match "/test_.+\\.py$" :modes (python-mode))
|
(associate! nose-mode :match "/test_.+\\.py$" :modes (python-mode))
|
||||||
:config
|
:config
|
||||||
(set! :popup "^\\*nosetests" '((size . 0.4)) '((select)))
|
(set-popup-rule! "^\\*nosetests" '((size . 0.4)) '((select)))
|
||||||
(set! :yas-minor-mode 'nose-mode)
|
(set! :yas-minor-mode 'nose-mode)
|
||||||
(map! :map nose-mode-map
|
(map! :map nose-mode-map
|
||||||
:localleader
|
:localleader
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
(def-package! restclient
|
(def-package! restclient
|
||||||
:mode ("\\.http\\'" . restclient-mode)
|
:mode ("\\.http\\'" . restclient-mode)
|
||||||
:config
|
:config
|
||||||
(set! :popup "^\\*HTTP Response" '((size . 0.4)) '((quit . other)))
|
(set-popup-rule! "^\\*HTTP Response" '((size . 0.4)) '((quit . other)))
|
||||||
(map! :mode restclient-mode
|
(map! :mode restclient-mode
|
||||||
:n [M-return] 'restclient-http-send-current
|
:n [M-return] 'restclient-http-send-current
|
||||||
:localleader
|
:localleader
|
||||||
|
@ -15,4 +15,4 @@
|
||||||
(def-package! company-restclient
|
(def-package! company-restclient
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after restclient
|
:after restclient
|
||||||
:config (set! :company-backend 'restclient-mode 'company-restclient))
|
:config (set-company-backend! 'restclient-mode 'company-restclient))
|
||||||
|
|
|
@ -14,7 +14,7 @@
|
||||||
(def-package! ruby-mode
|
(def-package! ruby-mode
|
||||||
:mode "\\.\\(?:pry\\|irb\\)rc\\'"
|
:mode "\\.\\(?:pry\\|irb\\)rc\\'"
|
||||||
:config
|
:config
|
||||||
(set! :company-backend 'ruby-mode 'company-dabbrev-code)
|
(set-company-backend! 'ruby-mode 'company-dabbrev-code)
|
||||||
(set! :electric 'ruby-mode :words '("else" "end" "elseif"))
|
(set! :electric 'ruby-mode :words '("else" "end" "elseif"))
|
||||||
(set! :env "RBENV_ROOT")
|
(set! :env "RBENV_ROOT")
|
||||||
(set! :repl 'ruby-mode #'inf-ruby) ; `inf-ruby'
|
(set! :repl 'ruby-mode #'inf-ruby) ; `inf-ruby'
|
||||||
|
@ -104,7 +104,7 @@ environment variables."
|
||||||
(def-package! company-inf-ruby
|
(def-package! company-inf-ruby
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after inf-ruby
|
:after inf-ruby
|
||||||
:config (set! :company-backend 'inf-ruby-mode 'company-inf-ruby))
|
:config (set-company-backend! 'inf-ruby-mode 'company-inf-ruby))
|
||||||
|
|
||||||
|
|
||||||
;; `rake'
|
;; `rake'
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
(def-package! company-racer
|
(def-package! company-racer
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after racer
|
:after racer
|
||||||
:config (set! :company-backend 'rust-mode '(company-racer)))
|
:config (set-company-backend! 'rust-mode '(company-racer)))
|
||||||
|
|
||||||
|
|
||||||
(def-package! flycheck-rust
|
(def-package! flycheck-rust
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
;; let DOOM handle company setup
|
;; let DOOM handle company setup
|
||||||
ensime-completion-style nil)
|
ensime-completion-style nil)
|
||||||
|
|
||||||
(set! :company-backend 'scala-mode '(ensime-company company-yasnippet))
|
(set-company-backend! 'scala-mode '(ensime-company company-yasnippet))
|
||||||
|
|
||||||
;; Fix void-variable imenu-auto-rescan error caused by `ensime--setup-imenu'
|
;; Fix void-variable imenu-auto-rescan error caused by `ensime--setup-imenu'
|
||||||
;; trying to make imenu variables buffer local before imenu is loaded.
|
;; trying to make imenu variables buffer local before imenu is loaded.
|
||||||
|
|
|
@ -59,6 +59,6 @@
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after sh-script
|
:after sh-script
|
||||||
:config
|
:config
|
||||||
(set! :company-backend 'sh-mode '(company-shell company-files))
|
(set-company-backend! 'sh-mode '(company-shell company-files))
|
||||||
(setq company-shell-delete-duplicates t))
|
(setq company-shell-delete-duplicates t))
|
||||||
|
|
||||||
|
|
|
@ -25,4 +25,4 @@
|
||||||
:after solidity-mode
|
:after solidity-mode
|
||||||
:config
|
:config
|
||||||
(setq company-backends (delq 'company-solidity company-backends))
|
(setq company-backends (delq 'company-solidity company-backends))
|
||||||
(set! :company-backends 'solidity-mode 'company-solidity))
|
(set-company-backend! 'solidity-mode 'company-solidity))
|
||||||
|
|
|
@ -15,5 +15,5 @@
|
||||||
:when (featurep! :completion company)
|
:when (featurep! :completion company)
|
||||||
:after swift-mode
|
:after swift-mode
|
||||||
:config
|
:config
|
||||||
(set! :company-backend 'swift-mode '(company-sourcekit company-yasnippet)))
|
(set-company-backend! 'swift-mode '(company-sourcekit company-yasnippet)))
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@
|
||||||
(set! :docset 'scss-mode "Sass")
|
(set! :docset 'scss-mode "Sass")
|
||||||
(unless EMACS26+
|
(unless EMACS26+
|
||||||
;; css-mode's built in completion is superior
|
;; css-mode's built in completion is superior
|
||||||
(set! :company-backend '(css-mode scss-mode) 'company-css))
|
(set-company-backend! '(css-mode scss-mode) 'company-css))
|
||||||
(map! :map scss-mode-map :localleader :n "b" #'+css/scss-build))
|
(map! :map scss-mode-map :localleader :n "b" #'+css/scss-build))
|
||||||
|
|
||||||
|
|
||||||
|
@ -50,6 +50,6 @@
|
||||||
:defer t
|
:defer t
|
||||||
:config
|
:config
|
||||||
(set! :docset 'sass-mode "Sass")
|
(set! :docset 'sass-mode "Sass")
|
||||||
(set! :company-backend 'sass-mode 'company-css)
|
(set-company-backend! 'sass-mode 'company-css)
|
||||||
(map! :map scss-mode-map :localleader :n "b" #'+css/sass-build))
|
(map! :map scss-mode-map :localleader :n "b" #'+css/sass-build))
|
||||||
|
|
||||||
|
|
|
@ -92,6 +92,9 @@
|
||||||
|
|
||||||
|
|
||||||
;;
|
;;
|
||||||
(set! :company-backend 'pug-mode 'company-web-jade)
|
(after! pug-mode
|
||||||
(set! :company-backend 'web-mode 'company-web-html)
|
(set-company-backend! 'pug-mode 'company-web-jade))
|
||||||
(set! :company-backend 'slim-mode 'company-web-slim)
|
(after! web-mode
|
||||||
|
(set-company-backend! 'web-mode 'company-web-html))
|
||||||
|
(after! slim-mode
|
||||||
|
(set-company-backend! 'slim-mode 'company-web-slim))
|
||||||
|
|
|
@ -16,18 +16,19 @@
|
||||||
;; Slice images into rows; easier to navigate around images
|
;; Slice images into rows; easier to navigate around images
|
||||||
ein:slice-image t)
|
ein:slice-image t)
|
||||||
|
|
||||||
(set! :popup "\\*ein: .*" :ignore)
|
(set-popup-rules!
|
||||||
(set! :popup "\\*ein:tb .*"
|
'(("\\*ein: .*" :ignore t)
|
||||||
'((side . bottom) (size . 0.3))
|
("\\*ein:tb .*"
|
||||||
'((quit . t) (transient) (select)))
|
((side . bottom) (size . 0.3))
|
||||||
(set! :popup "\\*ein:notebooklist *"
|
((quit . t) (transient) (select)))
|
||||||
'((side . left) (size . 50))
|
("\\*ein:notebooklist *"
|
||||||
'((select)))
|
((side . left) (size . 50))
|
||||||
|
((select)))))
|
||||||
|
|
||||||
(when (featurep! :completion company)
|
(when (featurep! :completion company)
|
||||||
;; Code completion with company
|
;; Code completion with company
|
||||||
(setq ein:completion-backend 'ein:use-company-backend)
|
(setq ein:completion-backend 'ein:use-company-backend)
|
||||||
(set! :company-backend '(ein:notebook-multilang-mode
|
(set-company-backend! '(ein:notebook-multilang-mode
|
||||||
ein:notebook-python-mode
|
ein:notebook-python-mode
|
||||||
ein:notebook-plain-mode)
|
ein:notebook-plain-mode)
|
||||||
'ein:company-backend))
|
'ein:company-backend))
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
;; Emacs.
|
;; Emacs.
|
||||||
|
|
||||||
(after! gist
|
(after! gist
|
||||||
(set! :evil-state 'gist-list-mode 'normal)
|
(set-evil-initial-state! 'gist-list-mode 'normal)
|
||||||
|
|
||||||
(defun +gist*list-render (orig-fn &rest args)
|
(defun +gist*list-render (orig-fn &rest args)
|
||||||
(funcall orig-fn (car args) t)
|
(funcall orig-fn (car args) t)
|
||||||
|
|
|
@ -25,7 +25,7 @@ load everything.")
|
||||||
magit-diff-refine-hunk t ;; Show word-granularity on the currently selected hunk
|
magit-diff-refine-hunk t ;; Show word-granularity on the currently selected hunk
|
||||||
magit-display-buffer-function #'+magit-display-buffer-fullscreen)
|
magit-display-buffer-function #'+magit-display-buffer-fullscreen)
|
||||||
|
|
||||||
(set! :popup "^\\(?:\\*magit\\|magit:\\)" :ignore)
|
(set-popup-rule! "^\\(?:\\*magit\\|magit:\\)" :ignore)
|
||||||
;; Consider magit buffers real (so they can switched to)
|
;; Consider magit buffers real (so they can switched to)
|
||||||
(add-hook 'magit-mode-hook #'doom|mark-buffer-as-real)
|
(add-hook 'magit-mode-hook #'doom|mark-buffer-as-real)
|
||||||
;; no mode-line in magit popups
|
;; no mode-line in magit popups
|
||||||
|
|
|
@ -27,8 +27,8 @@
|
||||||
;; `pass'
|
;; `pass'
|
||||||
(after! pass
|
(after! pass
|
||||||
(set! :env "PASSWORD_STORE_DIR")
|
(set! :env "PASSWORD_STORE_DIR")
|
||||||
(set! :evil-state 'pass-mode 'emacs)
|
(set-evil-initial-state! 'pass-mode 'emacs)
|
||||||
(set! :popup "^\\*Password-Store"
|
(set-popup-rule! "^\\*Password-Store"
|
||||||
'((side . left) (size . 0.25))
|
'((side . left) (size . 0.25))
|
||||||
'((quit)))
|
'((quit)))
|
||||||
(define-key! pass-mode-map
|
(define-key! pass-mode-map
|
||||||
|
|
|
@ -18,9 +18,9 @@
|
||||||
(load! "+modeline")
|
(load! "+modeline")
|
||||||
(add-hook! 'pdf-tools-enabled-hook (doom-set-modeline 'pdf-tools-modeline)))
|
(add-hook! 'pdf-tools-enabled-hook (doom-set-modeline 'pdf-tools-modeline)))
|
||||||
;; Handle PDF-tools related popups better
|
;; Handle PDF-tools related popups better
|
||||||
(set! :popup "^\\*Outline*" '((side . right) (size . 40)) '((select)))
|
(set-popup-rule! "^\\*Outline*" '((side . right) (size . 40)) '((select)))
|
||||||
;; TODO: Add additional important windows that should be handled differently
|
;; TODO: Add additional important windows that should be handled differently
|
||||||
;; TODO: These two next rules don't work (they should), investigate
|
;; TODO: These two next rules don't work (they should), investigate
|
||||||
;; (set! :popup "\\*Contents\\*" '((side . right) (size . 40)) nil)
|
;; (set-popup-rule! "\\*Contents\\*" '((side . right) (size . 40)) nil)
|
||||||
;; (set! :popup "* annots\\*$" '((side . left) (size . 40)) '((select)))
|
;; (set-popup-rule! "* annots\\*$" '((side . left) (size . 40)) '((select)))
|
||||||
)
|
)
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
;;; tools/prodigy/config.el -*- lexical-binding: t; -*-
|
;;; tools/prodigy/config.el -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
(after! prodigy
|
(after! prodigy
|
||||||
(set! :evil-state 'prodigy-mode 'emacs)
|
(set-evil-initial-state! 'prodigy-mode 'emacs)
|
||||||
|
|
||||||
;; Make services, etc persistent between Emacs sessions
|
;; Make services, etc persistent between Emacs sessions
|
||||||
(doom-cache-persist
|
(doom-cache-persist
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
"~$"
|
"~$"
|
||||||
"^#.*#$"))
|
"^#.*#$"))
|
||||||
|
|
||||||
(set! :popup "^ ?\\*NeoTree"
|
(set-popup-rule! "^ ?\\*NeoTree"
|
||||||
`((side . ,neo-window-position) (size . ,neo-window-width))
|
`((side . ,neo-window-position) (size . ,neo-window-width))
|
||||||
'((quit . current) (select . t)))
|
'((quit . current) (select . t)))
|
||||||
|
|
||||||
|
|
|
@ -263,7 +263,7 @@ instead of switch-to-buffer-*."
|
||||||
(inhibit-same-window . t)))
|
(inhibit-same-window . t)))
|
||||||
|
|
||||||
(add-hook 'pdf-annot-list-mode-hook #'hide-mode-line-mode)
|
(add-hook 'pdf-annot-list-mode-hook #'hide-mode-line-mode)
|
||||||
(set! :popup "\\(^\\*Contents\\|'s annots\\*$\\)" :ignore t))
|
(set-popup-rule! "\\(^\\*Contents\\|'s annots\\*$\\)" :ignore t))
|
||||||
|
|
||||||
|
|
||||||
;; `wgrep'
|
;; `wgrep'
|
||||||
|
|
|
@ -1,72 +1,4 @@
|
||||||
;;; ui/popup/autoload.el -*- lexical-binding: t; -*-
|
;;; ui/popup/autoload/popup.el -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(defvar +popup--display-buffer-alist nil)
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(def-setting! :popup (condition &optional alist parameters)
|
|
||||||
"Define a popup rule.
|
|
||||||
|
|
||||||
CONDITION can be a regexp string or a function.
|
|
||||||
|
|
||||||
For ALIST, see `display-buffer' and `display-buffer-alist' for a list of
|
|
||||||
possible entries, which instruct the display system how to initialize the popup
|
|
||||||
window.
|
|
||||||
|
|
||||||
ALIST also supports the `size' parameter, which will be translated to
|
|
||||||
`window-width' or `window-height' depending on `side'.
|
|
||||||
|
|
||||||
PARAMETERS is an alist of window parameters. See `+popup-window-parameters' for
|
|
||||||
a list of custom parameters provided by the popup module. If certain
|
|
||||||
attributes/parameters are omitted, the ones from `+popup-default-alist' and
|
|
||||||
`+popup-default-parameters' will be used.
|
|
||||||
|
|
||||||
The buffers of new windows displayed by `pop-to-buffer' and `display-buffer'
|
|
||||||
will be tested against CONDITION, which is either a) a regexp string (which is
|
|
||||||
matched against the buffer's name) or b) a function that takes no arguments and
|
|
||||||
returns a boolean."
|
|
||||||
`(progn
|
|
||||||
(when after-init-time
|
|
||||||
(setq +popup--display-buffer-alist
|
|
||||||
(map-delete +popup--display-buffer-alist ,condition)))
|
|
||||||
(push (+popup--rule (list ,condition ,alist ,parameters))
|
|
||||||
+popup--display-buffer-alist)
|
|
||||||
(when (bound-and-true-p +popup-mode)
|
|
||||||
(setq display-buffer-alist +popup--display-buffer-alist))
|
|
||||||
+popup--display-buffer-alist))
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(def-setting! :popups (&rest rules)
|
|
||||||
"Define multiple popup rules. See `doom--set:popup' for the specifications of
|
|
||||||
each individual rule.
|
|
||||||
|
|
||||||
(set! :popups
|
|
||||||
'(\"^ \\*\" ((slot . 1) (vslot . -1) (size . +popup-shrink-to-fit)))
|
|
||||||
'(\"^\\*\" ((slot . 1) (vslot . -1)) ((select . t))))"
|
|
||||||
`(progn
|
|
||||||
(dolist (rule (nreverse (list ,@rules)))
|
|
||||||
(when after-init-time
|
|
||||||
(setq +popup--display-buffer-alist
|
|
||||||
(map-delete +popup--display-buffer-alist (car rule))))
|
|
||||||
(push (+popup--rule rule) +popup--display-buffer-alist))
|
|
||||||
(when (bound-and-true-p +popup-mode)
|
|
||||||
(setq display-buffer-alist +popup--display-buffer-alist))
|
|
||||||
+popup--display-buffer-alist))
|
|
||||||
|
|
||||||
;;;###autoload
|
|
||||||
(defsubst +popup--rule (args)
|
|
||||||
(declare (indent 1))
|
|
||||||
(cl-destructuring-bind (condition &optional alist parameters) args
|
|
||||||
(if (eq alist :ignore)
|
|
||||||
(list condition nil)
|
|
||||||
`(,condition (+popup-buffer)
|
|
||||||
,@alist
|
|
||||||
(window-parameters ,@parameters)))))
|
|
||||||
|
|
||||||
|
|
||||||
;;
|
|
||||||
;; Library
|
|
||||||
;;
|
|
||||||
|
|
||||||
(defvar +popup--populate-wparams (not EMACS26+))
|
(defvar +popup--populate-wparams (not EMACS26+))
|
||||||
(defvar +popup--inhibit-transient nil)
|
(defvar +popup--inhibit-transient nil)
|
||||||
|
@ -135,6 +67,7 @@ and enables `+popup-buffer-mode'."
|
||||||
`transient' window parameter (see `+popup-window-parameters').
|
`transient' window parameter (see `+popup-window-parameters').
|
||||||
+ And finally deletes the window!"
|
+ And finally deletes the window!"
|
||||||
(let ((buffer (window-buffer window))
|
(let ((buffer (window-buffer window))
|
||||||
|
(inhibit-quit t)
|
||||||
ttl)
|
ttl)
|
||||||
(when (and (buffer-file-name buffer)
|
(when (and (buffer-file-name buffer)
|
||||||
(buffer-modified-p buffer)
|
(buffer-modified-p buffer)
|
||||||
|
@ -490,7 +423,7 @@ should match the arguments of `+popup-define' or the :popup setting."
|
||||||
(declare (indent defun))
|
(declare (indent defun))
|
||||||
`(let ((+popup--display-buffer-alist +popup--old-display-buffer-alist)
|
`(let ((+popup--display-buffer-alist +popup--old-display-buffer-alist)
|
||||||
display-buffer-alist)
|
display-buffer-alist)
|
||||||
,@(cl-loop for rule in rules collect `(set! :popup ,@rule))
|
,@(cl-loop for rule in rules collect `(set-popup-rule! ,@rule))
|
||||||
(when (bound-and-true-p +popup-mode)
|
(when (bound-and-true-p +popup-mode)
|
||||||
(setq display-buffer-alist +popup--display-buffer-alist))
|
(setq display-buffer-alist +popup--display-buffer-alist))
|
||||||
,@body))
|
,@body))
|
107
modules/ui/popup/autoload/settings.el
Normal file
107
modules/ui/popup/autoload/settings.el
Normal file
|
@ -0,0 +1,107 @@
|
||||||
|
;;; ui/popup/autoload/settings.el -*- lexical-binding: t; -*-
|
||||||
|
|
||||||
|
(defvar +popup--display-buffer-alist nil)
|
||||||
|
|
||||||
|
(defsubst +popup--rule (args)
|
||||||
|
(cl-destructuring-bind (condition &optional alist parameters) args
|
||||||
|
(if (eq alist :ignore)
|
||||||
|
(list condition nil)
|
||||||
|
`(,condition (+popup-buffer)
|
||||||
|
,@alist
|
||||||
|
(window-parameters ,@parameters)))))
|
||||||
|
|
||||||
|
(defun +popup--define (condition &optional alist parameters)
|
||||||
|
(when after-init-time
|
||||||
|
(setq +popup--display-buffer-alist
|
||||||
|
(map-delete +popup--display-buffer-alist condition)))
|
||||||
|
(push (+popup--rule (list condition alist parameters))
|
||||||
|
+popup--display-buffer-alist))
|
||||||
|
|
||||||
|
;;;###autodef
|
||||||
|
(defun set-popup-rule! (condition &optional alist parameters)
|
||||||
|
"Define a popup rule.
|
||||||
|
|
||||||
|
CONDITION can be a regexp string or a function.
|
||||||
|
|
||||||
|
For ALIST, see `display-buffer' and `display-buffer-alist' for a list of
|
||||||
|
possible entries, which instruct the display system how to initialize the popup
|
||||||
|
window.
|
||||||
|
|
||||||
|
ALIST also supports the `size' parameter, which will be translated to
|
||||||
|
`window-width' or `window-height' depending on `side'.
|
||||||
|
|
||||||
|
PARAMETERS is an alist of window parameters. See `+popup-window-parameters' for
|
||||||
|
a list of custom parameters provided by the popup module. If certain
|
||||||
|
attributes/parameters are omitted, the ones from `+popup-default-alist' and
|
||||||
|
`+popup-default-parameters' will be used.
|
||||||
|
|
||||||
|
The buffers of new windows displayed by `pop-to-buffer' and `display-buffer'
|
||||||
|
will be tested against CONDITION, which is either a) a regexp string (which is
|
||||||
|
matched against the buffer's name) or b) a function that takes no arguments and
|
||||||
|
returns a boolean.
|
||||||
|
|
||||||
|
See `def-popups!' for defining multiple rules in bulk."
|
||||||
|
(+popup--define condition alist parameters)
|
||||||
|
(when (bound-and-true-p +popup-mode)
|
||||||
|
(setq display-buffer-alist +popup--display-buffer-alist))
|
||||||
|
+popup--display-buffer-alist)
|
||||||
|
|
||||||
|
;;;###autodef
|
||||||
|
(defun set-popup-rules! (&rest rulesets)
|
||||||
|
"Define multiple popup rules. See `def-popup!' for the specifications of each
|
||||||
|
individual rule.
|
||||||
|
|
||||||
|
(set-popup-rules!
|
||||||
|
'((\"^ \\*\" ((slot . 1) (vslot . -1) (size . +popup-shrink-to-fit)))
|
||||||
|
(\"^\\*\" ((slot . 1) (vslot . -1)) ((select . t)))))"
|
||||||
|
(dolist (ruleset rulesets)
|
||||||
|
(dolist (rule ruleset)
|
||||||
|
(apply #'+popup--define rule)))
|
||||||
|
(when (bound-and-true-p +popup-mode)
|
||||||
|
(setq display-buffer-alist +popup--display-buffer-alist))
|
||||||
|
+popup--display-buffer-alist)
|
||||||
|
|
||||||
|
|
||||||
|
;;
|
||||||
|
;; Obsolete
|
||||||
|
;;
|
||||||
|
|
||||||
|
;; FIXME obsolete :popup
|
||||||
|
;;;###autoload
|
||||||
|
(def-setting! :popup (condition &optional alist parameters)
|
||||||
|
"Define a popup rule.
|
||||||
|
|
||||||
|
CONDITION can be a regexp string or a function.
|
||||||
|
|
||||||
|
For ALIST, see `display-buffer' and `display-buffer-alist' for a list of
|
||||||
|
possible entries, which instruct the display system how to initialize the popup
|
||||||
|
window.
|
||||||
|
|
||||||
|
ALIST also supports the `size' parameter, which will be translated to
|
||||||
|
`window-width' or `window-height' depending on `side'.
|
||||||
|
|
||||||
|
PARAMETERS is an alist of window parameters. See `+popup-window-parameters' for
|
||||||
|
a list of custom parameters provided by the popup module. If certain
|
||||||
|
attributes/parameters are omitted, the ones from `+popup-default-alist' and
|
||||||
|
`+popup-default-parameters' will be used.
|
||||||
|
|
||||||
|
The buffers of new windows displayed by `pop-to-buffer' and `display-buffer'
|
||||||
|
will be tested against CONDITION, which is either a) a regexp string (which is
|
||||||
|
matched against the buffer's name) or b) a function that takes no arguments and
|
||||||
|
returns a boolean.
|
||||||
|
|
||||||
|
See `def-popups!' for defining multiple rules in bulk."
|
||||||
|
:obsolete set-popup-rule!
|
||||||
|
`(set-popup-rule! ,condition ,alist ,parameters))
|
||||||
|
|
||||||
|
;; FIXME obsolete :popups
|
||||||
|
;;;###autoload
|
||||||
|
(def-setting! :popups (&rest rulesets)
|
||||||
|
"Define multiple popup rules. See `def-popup!' for the specifications of each
|
||||||
|
individual rule.
|
||||||
|
|
||||||
|
(set-popup-rules!
|
||||||
|
'((\"^ \\*\" ((slot . 1) (vslot . -1) (size . +popup-shrink-to-fit)))
|
||||||
|
(\"^\\*\" ((slot . 1) (vslot . -1)) ((select . t)))))"
|
||||||
|
:obsolete set-popup-rules!
|
||||||
|
`(set-popup-rules! ,@rulesets))
|
|
@ -102,45 +102,43 @@ deleted.")
|
||||||
;; Default popup rules & bootstrap
|
;; Default popup rules & bootstrap
|
||||||
;;
|
;;
|
||||||
|
|
||||||
(when (featurep! +all)
|
(set-popup-rules!
|
||||||
(set! :popups
|
(when (featurep! +all)
|
||||||
'("^ \\*" ((slot . 1) (vslot . -1) (size . +popup-shrink-to-fit)))
|
'(("^\\*" ((slot . 1) (vslot . -1)) ((select . t)))
|
||||||
'("^\\*" ((slot . 1) (vslot . -1)) ((select . t)))))
|
("^ \\*" ((slot . 1) (vslot . -1) (size . +popup-shrink-to-fit)))))
|
||||||
|
(when (featurep! +defaults)
|
||||||
(when (featurep! +defaults)
|
'(("^\\*Completions"
|
||||||
(set! :popups
|
((slot . -1) (vslot . -2))
|
||||||
'("^\\*Completions"
|
((transient . 0)))
|
||||||
((slot . -1) (vslot . -2))
|
("^\\*Compil\\(?:ation\\|e-Log\\)"
|
||||||
((transient . 0)))
|
((size . 0.3))
|
||||||
'("^\\*Compil\\(?:ation\\|e-Log\\)"
|
((transient . 0) (quit . t)))
|
||||||
((size . 0.3))
|
("^\\*\\(?:scratch\\|Messages\\)"
|
||||||
((transient . 0) (quit . t)))
|
nil
|
||||||
'("^\\*\\(?:scratch\\|Messages\\)"
|
((autosave . t) (transient)))
|
||||||
nil
|
("^\\*doom \\(?:term\\|eshell\\)"
|
||||||
((autosave . t) (transient)))
|
((size . 0.25) (vslot . -10))
|
||||||
'("^\\*doom \\(?:term\\|eshell\\)"
|
((select . t) (quit) (transient . 0)))
|
||||||
((size . 0.25) (vslot . -10))
|
("^\\*doom:"
|
||||||
((select . t) (quit) (transient . 0)))
|
((size . 0.35) (side . bottom))
|
||||||
'("^\\*doom:"
|
((autosave . t) (select . t) (modeline . t) (quit) (transient . t)))
|
||||||
((size . 0.35) (side . bottom))
|
("^\\*\\(?:\\(?:Pp E\\|doom e\\)val\\)"
|
||||||
((autosave . t) (select . t) (modeline . t) (quit) (transient . t)))
|
((size . +popup-shrink-to-fit))
|
||||||
'("^\\*\\(?:\\(?:Pp E\\|doom e\\)val\\)"
|
((transient . 0) (select . ignore)))
|
||||||
((size . +popup-shrink-to-fit))
|
("^\\*Customize"
|
||||||
((transient . 0) (select . ignore)))
|
((slot . 2) (side . right))
|
||||||
'("^\\*Customize"
|
((modeline . nil) (select . t) (quit . t)))
|
||||||
((slot . 2) (side . right))
|
("^ \\*undo-tree\\*"
|
||||||
((modeline . nil) (select . t) (quit . t)))
|
((slot . 2) (side . left) (size . 20))
|
||||||
'("^ \\*undo-tree\\*"
|
((modeline . nil) (select . t) (quit . t)))
|
||||||
((slot . 2) (side . left) (size . 20))
|
;; `help-mode', `helpful-mode'
|
||||||
((modeline . nil) (select . t) (quit . t)))
|
("^\\*[Hh]elp"
|
||||||
;; `help-mode', `helpful-mode'
|
((slot . 2) (vslot . 2) (size . 0.25))
|
||||||
'("^\\*[Hh]elp"
|
((select . t)))
|
||||||
((slot . 2) (vslot . 2) (size . 0.25))
|
;; `Info-mode'
|
||||||
((select . t)))
|
("^\\*info\\*$"
|
||||||
;; `Info-mode'
|
((slot . 2) (vslot . 2) (size . 0.45))
|
||||||
'("^\\*info\\*$"
|
((select . t))))))
|
||||||
((slot . 2) (vslot . 2) (size . 0.45))
|
|
||||||
((select . t)))))
|
|
||||||
|
|
||||||
(add-hook 'doom-init-ui-hook #'+popup-mode)
|
(add-hook 'doom-init-ui-hook #'+popup-mode)
|
||||||
(add-hook! '+popup-buffer-mode-hook
|
(add-hook! '+popup-buffer-mode-hook
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue