Introduce general.el & rewrite map!
+ Now uses an overriding keymap for leader keys, so that it is always
available, even outside of normal/visual states. In insert/emacs
states, or in sessions where evil is absent, an alternative prefix is
used for leader/localleader keys. See these variables:
+ doom-leader-prefix
+ doom-leader-alt-prefix
+ doom-localleader-prefix
+ doom-localleader-alt-prefix
+ Keybinds now support alternative prefixes through the new :alt-prefix
property. This is useful for non-evil users and non-normal evil
states. By default, this is M-SPC (leader) and M-SPC m (localleader).
+ Removed +evil-commands flag from config/default (moved to
feature/evil/+commands.el).
+ config/default/+bindings.el has been split into
config/default/+{evil,emacs}-bindings.el, which one is loaded depends
on whether evil is present or not. The latter is blank, but will soon
be populated with a keybinding scheme for non-evil users (perhaps
inspired by #641).
+ The define-key! macro has been replaced; it is now an alias for
general-def.
+ Added unmap! as an alias for general-unbind.
+ The following modifier key conventions are now enforced for
consistency, across all OSes:
alt/option = meta
windows/command = super
It used to be
alt/option = alt
windows/command = meta
Many of the default keybinds have been updated to reflect this switch,
but it is likely to affect personal meta/super keybinds!
The map! macro has also been rewritten to use general-define-key. Here
is what has been changed:
+ map! no longer works with characters, e.g. (map! ?x #'do-something) is
no longer supported. Keys must be kbd-able strings like "C-c x" or
vectors like [?C-c ?x].
+ The :map and :map* properties are now the same thing. If specified
keymaps aren't defined when binding keys, it is automatically
deferred.
+ The way you bind local keybinds has changed:
;; Don't do this
(map! :l "a" #'func-a
:l "b" #'func-b)
;; Do this
(map! :map 'local "a" #'func-a
"b" #'func-b)
+ map! now supports the following new blocks:
+ (:if COND THEN-FORM ELSE-FORM...)
+ (:alt-prefix PREFIX KEYS...) -- this prefix will be used for
non-normal evil states. Equivalent to :non-normal-prefix in general.
+ The way you declare a which-key label for a prefix key has changed:
;; before
(map! :desc "label" :prefix "a" ...)
;; now
(map! :prefix ("a" . "label") ...)
+ It used to be that map! supported binding a key to a key sequence,
like so:
(map! "a" [?x]) ; pressing a is like pressing x
This functionality was removed *temporarily* while I figure out the
implementation.
Addresses: #448, #814, #860
Mentioned in: #940
2018-12-22 03:30:04 -05:00
|
|
|
;;; config/default/+emacs-bindings.el -*- lexical-binding: t; -*-
|
|
|
|
|
2019-01-02 23:43:11 +01:00
|
|
|
;; Sensible deafult key bindings for non-evil users
|
2019-03-09 03:28:00 -05:00
|
|
|
(setq doom-leader-alt-key "C-c"
|
|
|
|
doom-localleader-alt-key "C-c l")
|
2019-01-02 23:43:11 +01:00
|
|
|
|
|
|
|
;; persp-mode and projectile in different prefixes
|
2019-03-09 03:28:00 -05:00
|
|
|
(setq persp-keymap-prefix (kbd "C-c w"))
|
2019-01-02 23:43:11 +01:00
|
|
|
(after! projectile
|
|
|
|
(define-key projectile-mode-map (kbd "C-c p") 'projectile-command-map))
|
|
|
|
|
2019-03-09 03:28:00 -05:00
|
|
|
(after! which-key
|
|
|
|
(which-key-add-key-based-replacements "C-c !" "checking")
|
|
|
|
(which-key-add-key-based-replacements "C-c l" "<localleader>"))
|
2019-01-02 23:43:11 +01:00
|
|
|
|
|
|
|
|
2019-03-09 03:28:00 -05:00
|
|
|
;;
|
|
|
|
;;; Global keybinds
|
2019-01-10 13:15:33 +01:00
|
|
|
|
2019-03-09 03:28:00 -05:00
|
|
|
(map! "C-'" #'imenu
|
|
|
|
;; Text scaling
|
|
|
|
"<C-mouse-4>" #'text-scale-increase
|
|
|
|
"<C-mouse-5>" #'text-scale-decrease
|
|
|
|
"<C-down-mouse-2>" (λ! (text-scale-set 0))
|
|
|
|
"M-+" (λ! (text-scale-set 0))
|
|
|
|
"M-=" #'text-scale-increase
|
|
|
|
"M--" #'text-scale-decrease
|
|
|
|
;; Editor related bindings
|
|
|
|
[remap newline] #'newline-and-indent
|
|
|
|
"C-j" #'+default/newline
|
|
|
|
(:when (featurep! :completion ivy)
|
|
|
|
"C-S-s" #'swiper
|
|
|
|
"C-S-r" #'ivy-resume)
|
|
|
|
(:when (featurep! :completion helm)
|
|
|
|
"C-S-s" #'swiper-helm
|
|
|
|
"C-S-r" #'helm-resume)
|
|
|
|
;; Buffer related bindings
|
|
|
|
"C-x b" #'persp-switch-to-buffer
|
|
|
|
(:when (featurep! :completion ivy)
|
|
|
|
"C-x 4 b" #'+ivy/switch-workspace-buffer-other-window)
|
|
|
|
"C-x C-b" #'ibuffer-list-buffers
|
|
|
|
"C-x B" #'switch-to-buffer
|
|
|
|
"C-x 4 B" #'switch-to-buffer-other-window
|
|
|
|
"C-x k" #'doom/kill-this-buffer-in-all-windows
|
|
|
|
;; Popup bindigns
|
|
|
|
"C-x p" #'+popup/other
|
|
|
|
"C-`" #'+popup/toggle
|
|
|
|
"C-~" #'+popup/raise)
|
2019-01-10 13:15:33 +01:00
|
|
|
|
2019-01-02 23:43:11 +01:00
|
|
|
|
2019-03-09 03:28:00 -05:00
|
|
|
;;
|
|
|
|
;;; Leader keys
|
2019-01-02 23:43:11 +01:00
|
|
|
|
2019-03-09 03:28:00 -05:00
|
|
|
(map! :leader
|
|
|
|
:desc "Find file in project" "C-f" #'projectile-find-file
|
|
|
|
:desc "Evaluate line/region" "e" #'+eval/line-or-region
|
|
|
|
:desc "Pop up scratch buffer" "x" #'doom/open-to-scratch-buffer
|
|
|
|
:desc "Switch to scratch buffer" "X" #'doom/switch-to-scratch-buffer
|
|
|
|
|
|
|
|
(:when (featurep! :emacs term)
|
|
|
|
:desc "Terminal" "`" #'+term/open
|
|
|
|
:desc "Terminal in popup" "~" #'+term/open-popup-in-project)
|
|
|
|
(:when (featurep! :tools vterm)
|
|
|
|
:desc "Terminal" "`" #'+vterm/open
|
|
|
|
:desc "Terminal in popup" "~" #'+vterm/open-popup-in-project)
|
|
|
|
(:when (featurep! :emacs eshell)
|
|
|
|
:desc "Eshell" "`" #'+eshell/open
|
|
|
|
:desc "Eshell in popup" "~" #'+eshell/open-popup)
|
|
|
|
|
|
|
|
;; Add labels to prefixes defined elsewhere
|
|
|
|
:desc "project" "p" nil
|
|
|
|
|
|
|
|
(:prefix ("f" . "file")
|
|
|
|
:desc "Find other file" "a" #'projectile-find-other-file
|
|
|
|
:desc "Browse private config" "c" #'doom/open-private-config
|
|
|
|
:desc "Find file in private config" "C" #'doom/find-file-in-private-config
|
|
|
|
:desc "Open project editorconfig" "." #'editorconfig-find-current-editorconfig
|
|
|
|
:desc "Find directory" "d" #'dired
|
|
|
|
:desc "Find file in emacs.d" "e" #'+default/find-in-emacsd
|
|
|
|
:desc "Browse emacs.d" "E" #'+default/browse-emacsd
|
|
|
|
:desc "Find file from here" "f" (if (fboundp 'counsel-file-jump) #'counsel-file-jump #'find-file)
|
|
|
|
:desc "Find file in other project" "F" #'doom/browse-in-other-project
|
|
|
|
:desc "Find file in project" "p" #'projectile-find-file
|
|
|
|
:desc "Find file in other project" "P" #'doom/find-file-in-other-project
|
|
|
|
:desc "Recent files" "r" #'recentf-open-files
|
|
|
|
:desc "Recent project files" "R" #'projectile-recentf
|
|
|
|
:desc "Sudo this file" "s" #'doom/sudo-this-file
|
|
|
|
:desc "Sudo find file" "S" #'doom/sudo-find-file
|
|
|
|
:desc "Delete this file" "X" #'doom/delete-this-file
|
|
|
|
:desc "Yank filename" "y" #'+default/yank-buffer-filename)
|
|
|
|
|
|
|
|
"o" nil ; we need to unbind it first as Org claims this
|
|
|
|
(:prefix ("o". "org")
|
|
|
|
:desc "Do what I mean" "o" #'+org/dwim-at-point
|
|
|
|
:desc "Sync org caldav" "s" #'org-caldav-sync
|
|
|
|
(:prefix ("a" . "org agenda")
|
|
|
|
:desc "Agenda" "a" #'org-agenda
|
|
|
|
:desc "Todo list" "t" #'org-todo-list
|
|
|
|
:desc "Tags view" "m" #'org-tags-view
|
|
|
|
:desc "View search" "v" #'org-search-view)
|
|
|
|
:desc "Capture" "c" #'org-capture
|
|
|
|
:desc "Goto capture" "C" (λ! (require 'org-capture) (call-interactively #'org-capture-goto-target))
|
|
|
|
:desc "Switch org buffers" "b" #'org-switchb
|
|
|
|
(:prefix ("e" . "org export")
|
|
|
|
:desc "Export beamer to latex" "l b" #'org-beamer-export-to-latex
|
|
|
|
:desc "Export beamer as latex" "l B" #'org-beamer-export-as-latex
|
|
|
|
:desc "Export beamer as pdf" "l P" #'org-beamer-export-to-pdf)
|
|
|
|
:desc "Link store" "l" #'org-store-link)
|
|
|
|
|
|
|
|
(:prefix ("q" . "quit/restart")
|
|
|
|
:desc "Quit Emacs" "q" #'kill-emacs
|
|
|
|
:desc "Save and quit Emacs" "Q" #'save-buffers-kill-terminal
|
|
|
|
(:when (featurep! :feature workspaces)
|
|
|
|
:desc "Quit Emacs & forget session" "X" #'+workspace/kill-session-and-quit)
|
|
|
|
:desc "Restart & restore Emacs" "r" #'doom/restart-and-restore
|
|
|
|
:desc "Restart Emacs" "R" #'doom/restart)
|
|
|
|
|
|
|
|
(:prefix ("&" . "snippets")
|
|
|
|
:desc "New snippet" "n" #'yas-new-snippet
|
|
|
|
:desc "Insert snippet" "i" #'yas-insert-snippet
|
|
|
|
:desc "Find global snippet" "/" #'yas-visit-snippet-file
|
|
|
|
:desc "Reload snippets" "r" #'yas-reload-all
|
|
|
|
:desc "Create Temp Template" "c" #'aya-create
|
|
|
|
:desc "Use Temp Template" "e" #'aya-expand)
|
|
|
|
|
|
|
|
(:prefix ("v" . "versioning")
|
|
|
|
:desc "Git revert file" "R" #'vc-revert
|
|
|
|
(:when (featurep! :ui vc-gutter)
|
|
|
|
:desc "Git revert hunk" "r" #'git-gutter:revert-hunk
|
|
|
|
:desc "Git stage hunk" "s" #'git-gutter:stage-hunk
|
|
|
|
:desc "Git time machine" "t" #'git-timemachine-toggle
|
|
|
|
:desc "Jump to next hunk" "n" #'git-gutter:next-hunk
|
|
|
|
:desc "Jump to previous hunk" "p" #'git-gutter:previous-hunk)
|
|
|
|
(:when (featurep! :tools magit)
|
|
|
|
:desc "Magit dispatch" "/" #'magit-dispatch
|
|
|
|
:desc "Forge dispatch" "'" #'forge-dispatch
|
|
|
|
:desc "Magit status" "g" #'magit-status
|
|
|
|
:desc "Magit file delete" "x" #'magit-file-delete
|
|
|
|
:desc "Magit blame" "B" #'magit-blame-addition
|
|
|
|
:desc "Magit clone" "C" #'+magit/clone
|
|
|
|
:desc "Magit fetch" "F" #'magit-fetch
|
|
|
|
:desc "Magit buffer log" "L" #'magit-log
|
|
|
|
:desc "Git stage file" "S" #'magit-stage-file
|
|
|
|
:desc "Git unstage file" "U" #'magit-unstage-file
|
|
|
|
(:prefix ("f" . "find")
|
|
|
|
:desc "Find file" "f" #'magit-find-file
|
|
|
|
:desc "Find gitconfig file" "g" #'magit-find-git-config-file
|
|
|
|
:desc "Find commit" "c" #'magit-show-commit
|
|
|
|
:desc "Find issue" "i" #'forge-visit-issue
|
|
|
|
:desc "Find pull request" "p" #'forge-visit-pullreq)
|
|
|
|
(:prefix ("o" . "open in browser")
|
|
|
|
:desc "Browse region or line" "." #'+vc/git-browse-region-or-line
|
|
|
|
:desc "Browse remote" "r" #'forge-browse-remote
|
|
|
|
:desc "Browse commit" "c" #'forge-browse-commit
|
|
|
|
:desc "Browse an issue" "i" #'forge-browse-issue
|
|
|
|
:desc "Browse a pull request" "p" #'forge-browse-pullreq
|
|
|
|
:desc "Browse issues" "I" #'forge-browse-issues
|
|
|
|
:desc "Browse pull requests" "P" #'forge-browse-pullreqs)
|
|
|
|
(:prefix ("l" . "list")
|
|
|
|
(:when (featurep! :tools gist)
|
|
|
|
:desc "List gists" "g" #'+gist:list)
|
|
|
|
:desc "List repositories" "r" #'magit-list-repositories
|
|
|
|
:desc "List submodules" "s" #'magit-list-submodules
|
|
|
|
:desc "List issues" "i" #'forge-list-issues
|
|
|
|
:desc "List pull requests" "p" #'forge-list-pullreqs
|
|
|
|
:desc "List notifications" "n" #'forge-list-notifications)
|
|
|
|
(:prefix ("c" . "create")
|
|
|
|
:desc "Initialize repo" "r" #'magit-init
|
|
|
|
:desc "Clone repo" "R" #'+magit/clone
|
|
|
|
:desc "Commit" "c" #'magit-commit-create
|
|
|
|
:desc "Issue" "i" #'forge-create-issue
|
|
|
|
:desc "Pull request" "p" #'forge-create-pullreq)))
|
|
|
|
|
|
|
|
(:prefix ("w" . "workspaces/windows")
|
|
|
|
:desc "Autosave session" "a" #'doom/quicksave-session
|
|
|
|
:desc "Display workspaces" "d" #'+workspace/display
|
|
|
|
:desc "Rename workspace" "r" #'+workspace/rename
|
|
|
|
:desc "Create workspace" "c" #'+workspace/new
|
|
|
|
:desc "Delete workspace" "k" #'+workspace/delete
|
|
|
|
:desc "Save session" "s" #'doom/save-session
|
|
|
|
:desc "Save workspace" "S" #'+workspace/save
|
|
|
|
:desc "Load session" "l" #'doom/load-session
|
|
|
|
:desc "Load last autosaved session" "L" #'doom/quickload-session
|
|
|
|
:desc "Kill other buffers" "o" #'doom/kill-other-buffers
|
|
|
|
:desc "Undo window config" "u" #'winner-undo
|
|
|
|
:desc "Redo window config" "U" #'winner-redo
|
|
|
|
:desc "Switch to left workspace" "p" #'+workspace/switch-left
|
|
|
|
:desc "Switch to right workspace" "n" #'+workspace/switch-right
|
|
|
|
:desc "Switch to" "w" #'+workspace/switch-to
|
|
|
|
:desc "Switch to workspace 1" "1" (λ! (+workspace/switch-to 0))
|
|
|
|
:desc "Switch to workspace 2" "2" (λ! (+workspace/switch-to 1))
|
|
|
|
:desc "Switch to workspace 3" "3" (λ! (+workspace/switch-to 2))
|
|
|
|
:desc "Switch to workspace 4" "4" (λ! (+workspace/switch-to 3))
|
|
|
|
:desc "Switch to workspace 5" "5" (λ! (+workspace/switch-to 4))
|
|
|
|
:desc "Switch to workspace 6" "6" (λ! (+workspace/switch-to 5))
|
|
|
|
:desc "Switch to workspace 7" "7" (λ! (+workspace/switch-to 6))
|
|
|
|
:desc "Switch to workspace 8" "8" (λ! (+workspace/switch-to 7))
|
|
|
|
:desc "Switch to workspace 9" "9" (λ! (+workspace/switch-to 8))
|
|
|
|
:desc "Switch to last workspace" "0" #'+workspace/switch-to-last)
|
|
|
|
|
|
|
|
(:when (featurep! :editor multiple-cursors)
|
|
|
|
(:prefix ("m" . "multiple cursors")
|
|
|
|
:desc "Edit lines" "l" #'mc/edit-lines
|
|
|
|
:desc "Mark next" "n" #'mc/mark-next-like-this
|
|
|
|
:desc "Unmark next" "N" #'mc/unmark-next-like-this
|
|
|
|
:desc "Mark previous" "p" #'mc/mark-previous-like-this
|
|
|
|
:desc "Unmark previous" "P" #'mc/unmark-previous-like-this
|
|
|
|
:desc "Mark all" "t" #'mc/mark-all-like-this
|
|
|
|
:desc "Mark all DWIM" "m" #'mc/mark-all-like-this-dwim
|
|
|
|
:desc "Edit line endings" "e" #'mc/edit-ends-of-lines
|
|
|
|
:desc "Edit line starts" "a" #'mc/edit-beginnings-of-lines
|
|
|
|
:desc "Mark tag" "s" #'mc/mark-sgml-tag-pair
|
|
|
|
:desc "Mark in defun" "d" #'mc/mark-all-like-this-in-defun
|
|
|
|
:desc "Add cursor w/mouse" "<mouse-1>" #'mc/add-cursor-on-click))
|
|
|
|
|
|
|
|
;; APPs
|
|
|
|
(:when (featurep! :app email)
|
|
|
|
(:prefix ("M" . "email")
|
|
|
|
:desc "Open email app" "M" #'=email
|
|
|
|
:desc "Compose email" "c" #'+email/compose))
|
|
|
|
|
|
|
|
(:when (featurep! :app irc)
|
|
|
|
(:prefix ("I" . "irc")
|
|
|
|
:desc "Open irc app" "I" #'=irc
|
|
|
|
:desc "Next unread buffer" "a" #'tracking-next-buffer
|
|
|
|
:desc "Quit irc" "q" #'+irc/quit
|
|
|
|
:desc "Reconnect all" "r" #'circe-reconnect-all
|
|
|
|
:desc "Send message" "s" #'+irc/send-message
|
|
|
|
(:when (featurep! :completion ivy)
|
|
|
|
:desc "Jump to channel" "j" #'irc/ivy-jump-to-channel)))
|
|
|
|
|
|
|
|
(:when (featurep! :app twitter)
|
|
|
|
(:prefix ("T" . "twitter")
|
|
|
|
:desc "Open twitter app" "T" #'=twitter
|
|
|
|
:desc "Quit twitter" "q" #'+twitter/quit
|
|
|
|
:desc "Rerender twits" "r" #'+twitter/rerender-all
|
|
|
|
:desc "Ace link" "l" #'+twitter/ace-link)))
|
|
|
|
|
|
|
|
|
|
|
|
;;
|
|
|
|
;;; Plugins
|
|
|
|
|
|
|
|
(map! "C-=" #'er/expand-region
|
|
|
|
"C--" #'er/contract-region
|
|
|
|
(:when (featurep! :ui neotree)
|
|
|
|
"<f9>" #'+neotree/open
|
|
|
|
"<F-f9>" #'+neotree/find-this-file)
|
|
|
|
(:when (featurep! :ui treemacs)
|
|
|
|
"<f9>" #'+treemacs/open
|
|
|
|
"<F-f9>" #'+treemacs/find-file)
|
|
|
|
;; smartparens
|
|
|
|
(:after smartparens
|
|
|
|
:map smartparens-mode-map
|
|
|
|
"C-M-a" #'sp-beginning-of-sexp
|
|
|
|
"C-M-e" #'sp-end-of-sexp
|
|
|
|
"C-M-f" #'sp-forward-sexp
|
|
|
|
"C-M-b" #'sp-backward-sexp
|
|
|
|
"C-M-d" #'sp-splice-sexp
|
|
|
|
"C-M-k" #'sp-kill-sexp
|
|
|
|
"C-M-t" #'sp-transpose-sexp
|
|
|
|
"C-<right>" #'sp-forward-slurp-sexp
|
|
|
|
"M-<right>" #'sp-forward-barf-sexp
|
|
|
|
"C-<left>" #'sp-backward-slurp-sexp
|
|
|
|
"M-<left>" #'sp-backward-barf-sexp)
|
|
|
|
;; company mode
|
|
|
|
"C-;" #'+company/complete
|
|
|
|
;; Counsel
|
|
|
|
(:when (featurep! :completion ivy)
|
|
|
|
(:after counsel
|
|
|
|
:map counsel-ag-map
|
|
|
|
[backtab] #'+ivy/wgrep-occur ; search/replace on results
|
|
|
|
"C-SPC" #'ivy-call-and-recenter ; preview
|
|
|
|
"M-RET" (+ivy-do-action! #'+ivy-git-grep-other-window-action))
|
|
|
|
"C-M-y" #'counsel-yank-pop)
|
|
|
|
;; repl toggle
|
|
|
|
"C-c C-z" #'+eval/open-repl-other-window
|
|
|
|
;; company mode
|
|
|
|
(:after company
|
|
|
|
:map company-active-map
|
|
|
|
"C-o" #'company-search-kill-others
|
|
|
|
"C-n" #'company-select-next
|
|
|
|
"C-p" #'company-select-previous
|
|
|
|
"C-h" #'company-quickhelp-manual-begin
|
|
|
|
"C-S-h" #'company-show-doc-buffer
|
|
|
|
"C-s" #'company-search-candidates
|
|
|
|
"M-s" #'company-filter-candidates
|
|
|
|
"<C-tab>" #'company-complete-common-or-cycle
|
|
|
|
[tab] #'company-complete-common-or-cycle
|
|
|
|
[backtab] #'company-select-previous
|
|
|
|
"C-RET" #'counsel-company
|
|
|
|
:map company-search-map
|
|
|
|
"C-n" #'company-search-repeat-forward
|
|
|
|
"C-p" #'company-search-repeat-backward
|
|
|
|
"C-s" (λ! (company-search-abort) (company-filter-candidates)))
|
|
|
|
;; neotree bindings
|
|
|
|
(:after neotree
|
|
|
|
:map neotree-mode-map
|
|
|
|
"q" #'neotree-hide
|
|
|
|
"RET" #'neotree-enter
|
|
|
|
"SPC" #'neotree-quick-look
|
|
|
|
"v" #'neotree-enter-vertical-split
|
|
|
|
"s" #'neotree-enter-horizontal-split
|
|
|
|
"c" #'neotree-create-node
|
|
|
|
"D" #'neotree-delete-node
|
|
|
|
"g" #'neotree-refresh
|
|
|
|
"r" #'neotree-rename-node
|
|
|
|
"R" #'neotree-refresh
|
|
|
|
"h" #'+neotree/collapse-or-up
|
|
|
|
"l" #'+neotree/expand-or-open
|
|
|
|
"n" #'neotree-next-line
|
|
|
|
"p" #'neotree-previous-line
|
|
|
|
"N" #'neotree-select-next-sibling-node
|
|
|
|
"P" #'neotree-select-previous-sibling-node)
|
|
|
|
;; help and info
|
|
|
|
(:after help-mode
|
|
|
|
:map help-mode-map
|
|
|
|
"o" #'ace-link-help
|
|
|
|
">" #'help-go-forward
|
|
|
|
"<" #'help-go-back)
|
|
|
|
(:after helpful-mode
|
|
|
|
:map helpful-mode-map
|
|
|
|
"o" #'ace-link-help)
|
2019-03-12 14:21:41 +10:00
|
|
|
(:after apropos
|
|
|
|
:map apropos-mode-map
|
|
|
|
"o" #'ace-link-help
|
|
|
|
"n" #'forward-button
|
|
|
|
"p" #'backward-button)
|
2019-03-09 03:28:00 -05:00
|
|
|
(:after info
|
|
|
|
:map Info-mode-map
|
|
|
|
"o" #'ace-link-info)
|
|
|
|
;; yasnippet
|
|
|
|
(:after yasnippet
|
|
|
|
;; keymap while editing an inserted snippet
|
|
|
|
:map yas-keymap
|
|
|
|
"C-e" #'+snippets/goto-end-of-field
|
|
|
|
"C-a" #'+snippets/goto-start-of-field
|
|
|
|
"<S-tab>" #'yas-prev-field
|
|
|
|
"<M-backspace>" #'+snippets/delete-to-start-of-field
|
|
|
|
[backspace] #'+snippets/delete-backward-char
|
|
|
|
[delete] #'+snippets/delete-forward-char-or-field)
|
|
|
|
;; flycheck
|
|
|
|
(:after flycheck
|
|
|
|
:map flycheck-error-list-mode-map
|
|
|
|
"C-n" #'flycheck-error-list-next-error
|
|
|
|
"C-p" #'flycheck-error-list-previous-error
|
|
|
|
"RET" #'flycheck-error-list-goto-error)
|
|
|
|
;; ivy
|
|
|
|
(:after ivy
|
|
|
|
:map ivy-minibuffer-map
|
|
|
|
"TAB" #'ivy-alt-done
|
|
|
|
"C-g" #'keyboard-escape-quit)
|
|
|
|
;; ein notebokks
|
|
|
|
(:after ein:notebook-multilang
|
|
|
|
:map ein:notebook-multilang-mode-map
|
|
|
|
"C-c h" #'+ein/hydra/body))
|