feat(emacs): further improve emacs config
This commit is contained in:
parent
df5a94b1e6
commit
89029584ab
@ -1 +1,3 @@
|
|||||||
(set-face-attribute 'default nil :family "FiraCode Nerd Font" :height 120)
|
(set-face-attribute 'default nil :family "FiraCode Nerd Font" :height 120)
|
||||||
|
(set-face-attribute 'fixed-pitch nil :family "FiraCode Nerd Font":height 130)
|
||||||
|
(set-face-attribute 'variable-pitch nil :family "FiraCode Nerd Font":height 130)
|
||||||
|
@ -51,9 +51,11 @@
|
|||||||
(elpaca-wait)
|
(elpaca-wait)
|
||||||
|
|
||||||
(general-create-definer key-leader
|
(general-create-definer key-leader
|
||||||
|
:states 'normal
|
||||||
:prefix "SPC")
|
:prefix "SPC")
|
||||||
|
|
||||||
(general-create-definer key-local-leader
|
(general-create-definer key-local-leader
|
||||||
|
:states 'normal
|
||||||
:prefix ";")
|
:prefix ";")
|
||||||
|
|
||||||
|
|
||||||
@ -103,7 +105,7 @@
|
|||||||
:states 'normal
|
:states 'normal
|
||||||
"w w" #'which-key-show-top-level)
|
"w w" #'which-key-show-top-level)
|
||||||
:custom
|
:custom
|
||||||
(which-key-idle-delay 0.1)
|
(which-key-idle-delay 1)
|
||||||
(which-key-max-description-length 50)
|
(which-key-max-description-length 50)
|
||||||
:init
|
:init
|
||||||
(which-key-mode))
|
(which-key-mode))
|
||||||
@ -127,6 +129,29 @@
|
|||||||
(doom-themes-visual-bell-config)
|
(doom-themes-visual-bell-config)
|
||||||
(doom-themes-org-config))
|
(doom-themes-org-config))
|
||||||
|
|
||||||
|
(use-package doom-modeline
|
||||||
|
:custom
|
||||||
|
(doom-modeline-height 25)
|
||||||
|
(doom-modeline-bar-width 5)
|
||||||
|
(doom-modeline-icon t)
|
||||||
|
(doom-modeline-major-mode-icon t)
|
||||||
|
(doom-modeline-major-mode-color-icon t)
|
||||||
|
(doom-modeline-buffer-file-name-style 'truncate-upto-project)
|
||||||
|
(doom-modeline-buffer-state-icon t)
|
||||||
|
(doom-modeline-buffer-modification-icon t)
|
||||||
|
(doom-modeline-minor-modes nil)
|
||||||
|
(doom-modeline-enable-word-count nil)
|
||||||
|
(doom-modeline-buffer-encoding t)
|
||||||
|
(doom-modeline-indent-info nil)
|
||||||
|
(doom-modeline-checker-simple-format t)
|
||||||
|
(doom-modeline-vcs-max-length 12)
|
||||||
|
(doom-modeline-env-version t)
|
||||||
|
(doom-modeline-irc-stylize 'identity)
|
||||||
|
(doom-modeline-github-timer nil)
|
||||||
|
(doom-modeline-gnus-timer nil)
|
||||||
|
:config
|
||||||
|
(doom-modeline-mode))
|
||||||
|
|
||||||
(use-package nerd-icons)
|
(use-package nerd-icons)
|
||||||
|
|
||||||
(use-package nerd-icons-ibuffer
|
(use-package nerd-icons-ibuffer
|
||||||
@ -135,8 +160,8 @@
|
|||||||
|
|
||||||
(use-package nerd-icons-dired
|
(use-package nerd-icons-dired
|
||||||
:after nerd-icons
|
:after nerd-icons
|
||||||
:hook
|
:init
|
||||||
(dired-mode . nerd-icons-dired-mode))
|
(add-hook 'org-mode-hook (lambda () (org-bullets-mode 1))))
|
||||||
|
|
||||||
(use-package treemacs
|
(use-package treemacs
|
||||||
:defer t
|
:defer t
|
||||||
@ -182,9 +207,30 @@
|
|||||||
(which-key-allow-evil-operators t)
|
(which-key-allow-evil-operators t)
|
||||||
(evil-undo-system 'undo-redo)
|
(evil-undo-system 'undo-redo)
|
||||||
(evil-want-fine-undo t)
|
(evil-want-fine-undo t)
|
||||||
|
(evil-emacs-state-modes nil)
|
||||||
|
(evil-insert-state-modes nil)
|
||||||
|
(evil-motion-state-modes nil)
|
||||||
:config
|
:config
|
||||||
(evil-mode 1))
|
(evil-mode 1))
|
||||||
|
|
||||||
|
(use-package evil-matchit
|
||||||
|
:config
|
||||||
|
(global-evil-matchit-mode))
|
||||||
|
|
||||||
|
(use-package targets
|
||||||
|
:elpaca (:host github
|
||||||
|
:depth 1
|
||||||
|
:repo "noctuid/targets.el"
|
||||||
|
:custom
|
||||||
|
(targets-user-text-objects '((pipe "|" nil separator)
|
||||||
|
(paren "(" ")" pair :more-keys "b")
|
||||||
|
(bracket "[" "]" pair :more-keys "r")
|
||||||
|
(curly "{" "}" pair :more-keys "c")))
|
||||||
|
:config
|
||||||
|
(targets-setup t
|
||||||
|
:inside-key nil
|
||||||
|
:around-key nil
|
||||||
|
:remote-key nil)))
|
||||||
|
|
||||||
(use-package evil-surround
|
(use-package evil-surround
|
||||||
:config
|
:config
|
||||||
@ -195,6 +241,13 @@
|
|||||||
:config
|
:config
|
||||||
(evil-collection-init))
|
(evil-collection-init))
|
||||||
|
|
||||||
|
;; Allow to jump to characters, etc.
|
||||||
|
(use-package avy
|
||||||
|
:general
|
||||||
|
(:keymaps 'normal
|
||||||
|
"f" 'avy-goto-char))
|
||||||
|
|
||||||
|
;; Improved PDF Experience
|
||||||
(use-package pdf-tools
|
(use-package pdf-tools
|
||||||
:config
|
:config
|
||||||
(pdf-tools-install)
|
(pdf-tools-install)
|
||||||
@ -305,13 +358,6 @@
|
|||||||
(global-corfu-mode)
|
(global-corfu-mode)
|
||||||
(corfu-popupinfo-mode))
|
(corfu-popupinfo-mode))
|
||||||
|
|
||||||
(use-package corfu-candidate-overlay
|
|
||||||
:after corfu
|
|
||||||
:config
|
|
||||||
;; enable corfu-candidate-overlay mode globally
|
|
||||||
;; this relies on having corfu-auto set to nil
|
|
||||||
(corfu-candidate-overlay-mode +1))
|
|
||||||
|
|
||||||
;; Add extensions
|
;; Add extensions
|
||||||
(use-package cape
|
(use-package cape
|
||||||
:elpaca (:host github
|
:elpaca (:host github
|
||||||
@ -459,12 +505,17 @@
|
|||||||
:init
|
:init
|
||||||
(marginalia-mode))
|
(marginalia-mode))
|
||||||
|
|
||||||
;; (use-package embark
|
(use-package embark
|
||||||
;; :after marginalia
|
:after marginalia
|
||||||
;; :custom
|
:general
|
||||||
;; (prefix-help-command #'embark-prefix-help-command)
|
("C-." 'embark-act)
|
||||||
;; :init)
|
:custom
|
||||||
|
(prefix-help-command #'embark-prefix-help-command)
|
||||||
|
:init)
|
||||||
|
|
||||||
|
(use-package embark-consult
|
||||||
|
:hook
|
||||||
|
(embark-collect-mode . consult-preview-at-point-mode))
|
||||||
|
|
||||||
(use-package consult
|
(use-package consult
|
||||||
:init
|
:init
|
||||||
@ -478,9 +529,9 @@
|
|||||||
:general
|
:general
|
||||||
(key-leader
|
(key-leader
|
||||||
:states 'normal
|
:states 'normal
|
||||||
"c" '(nil :which-key "Consult"))
|
"c" '(nil :which-key "Consult")
|
||||||
(key-leader
|
"c b" '(consult-buffer :which-key "Consult: Buffers")
|
||||||
:states 'normal
|
"c f" '(consult-fd :which-key "Consult: Find File")
|
||||||
"c r" '(consult-recent-file :which-key "Consult: Recent Files")))
|
"c r" '(consult-recent-file :which-key "Consult: Recent Files")))
|
||||||
|
|
||||||
|
|
||||||
@ -538,21 +589,50 @@
|
|||||||
|
|
||||||
;; Setup Language Servers
|
;; Setup Language Servers
|
||||||
|
|
||||||
(general-create-definer key-lsp-leader
|
|
||||||
:prefix "SPC l")
|
|
||||||
|
|
||||||
(use-package lsp-mode
|
(use-package lsp-mode
|
||||||
:init
|
:general
|
||||||
;; set prefix for lsp-command-keymap (few alternatives - "C-l", "C-c l")
|
(key-leader
|
||||||
(setq lsp-keymap-prefix "SPC l")
|
:states 'visual
|
||||||
|
"l f r" '(lsp-format-buffer :which-key "LSP Format: Region"))
|
||||||
|
(key-leader
|
||||||
|
:states 'normal
|
||||||
|
"k" '(lsp-ui-doc-glance :which-key "LSP: Glance Symbol")
|
||||||
|
"K" '(lsp-describe-thing-at-point :which-key "LSP: Full Doc")
|
||||||
|
"l" '(nil :which-key "LSP")
|
||||||
|
"l f" '(nil :which-key "LSP Format")
|
||||||
|
"l f f" '(lsp-format-buffer :which-key "LSP Format: Buffer")
|
||||||
|
"l i" '(lsp-treemacs-implementations :which-key "LSP: Implementation")
|
||||||
|
"l r" '(lsp-treemacs-references :which-key "LSP: Refrences")
|
||||||
|
"l n" '(lsp-rename :which-key "LSP: Rename")
|
||||||
|
"l R" '(lsp-restart :which-key "LSP: Restart")
|
||||||
|
"l d" '(lsp-find-definition :which-key "LSP: Definition")
|
||||||
|
"l D" '(lsp-find-declaration :which-key "LSP: Declaration")
|
||||||
|
"l c" '(lsp-execute-code-action :which-key "LSP: Code Actions")
|
||||||
|
"l t" '(nil :which-key "LSP Treemacs")
|
||||||
|
"l t e" '(lsp-treemacs-errors-list :which-key "LSP Treemacs: Errors List")
|
||||||
|
"l t s" '(lsp-treemacs-symbols :which-key "LSP Treemacs: Symbols")
|
||||||
|
"l t q" '(lsp-treemacs-quick-fix :which-key "LSP Treemacs: Quickfix")
|
||||||
|
"l t h" '(lsp-treemacs-call-heirarchy :which-key "LSP Treemacs: Call Hierarchy"))
|
||||||
|
:custom
|
||||||
|
(lsp-keymap-prefix "M-l")
|
||||||
|
(lsp-auto-execute-action 'nil)
|
||||||
:hook (;; replace XXX-mode with concrete major-mode(e. g. python-mode)
|
:hook (;; replace XXX-mode with concrete major-mode(e. g. python-mode)
|
||||||
;; (XXX-mode . lsp)
|
;; (XXX-mode . lsp)
|
||||||
;; if you want which-key integration
|
;; if you want which-key integration
|
||||||
(lsp-mode . lsp-enable-which-key-integration))
|
(lsp-mode . lsp-enable-which-key-integration))
|
||||||
:commands lsp)
|
:commands lsp
|
||||||
|
:config
|
||||||
|
(with-eval-after-load 'lsp-mode
|
||||||
|
(lsp-treemacs-sync-mode)
|
||||||
|
(setq lsp-modeline-diagnostics-scope :workspace)))
|
||||||
|
|
||||||
;; optionally
|
;; optionally
|
||||||
(use-package lsp-ui :commands lsp-ui-mode)
|
(use-package lsp-ui
|
||||||
|
:custom
|
||||||
|
(lsp-ui-doc-delay 0.1)
|
||||||
|
:commands
|
||||||
|
lsp-ui-mode
|
||||||
|
lsp-ui-doc-enable)
|
||||||
|
|
||||||
;; optionally if you want to use debugger
|
;; optionally if you want to use debugger
|
||||||
(use-package dap-mode
|
(use-package dap-mode
|
||||||
@ -569,19 +649,52 @@
|
|||||||
(dap-ui-mode)
|
(dap-ui-mode)
|
||||||
(dap-tooltip-mode)
|
(dap-tooltip-mode)
|
||||||
(dap-ui-controls-mode)
|
(dap-ui-controls-mode)
|
||||||
|
(dap-auto-configure-mode)
|
||||||
(dap-mode))
|
(dap-mode))
|
||||||
|
|
||||||
|
|
||||||
;; (use-package dap-LANGUAGE) to load the dap adapter for your language
|
|
||||||
|
|
||||||
;; Rust integration
|
;; Rust integration
|
||||||
(use-package rustic
|
(use-package rustic
|
||||||
:general
|
:general
|
||||||
(key-lsp-leader
|
(key-leader
|
||||||
:states 'normal))
|
:states 'normal
|
||||||
;; "f r" ((rustic-cargo-run) :which-key "Cargo: Run")))
|
"f r" '(rustic-cargo-run :which-key "Cargo: Run"))
|
||||||
|
:config
|
||||||
|
(rustic-mode))
|
||||||
|
|
||||||
;; Opacity
|
|
||||||
|
;;; Org Mode Appearance ------------------------------------
|
||||||
|
(use-package org-bullets
|
||||||
|
:hook (org-mode-hook . (lambda ()
|
||||||
|
(org-bullets-mode 1)
|
||||||
|
(org-toggle-pretty-entities))))
|
||||||
|
|
||||||
|
;; Load org-faces to make sure we can set appropriate faces
|
||||||
|
(require 'org-faces)
|
||||||
|
|
||||||
|
;; Hide emphasis markers on formatted text
|
||||||
|
(setq org-hide-emphasis-markers t)
|
||||||
|
|
||||||
|
;; Resize Org headings
|
||||||
|
(dolist (face '((org-level-1 . 1.45)
|
||||||
|
(org-level-2 . 1.35)
|
||||||
|
(org-level-3 . 1.3)
|
||||||
|
(org-level-4 . 1.25)
|
||||||
|
(org-level-5 . 1.2)
|
||||||
|
(org-level-6 . 1.15)
|
||||||
|
(org-level-7 . 1.1)
|
||||||
|
(org-level-8 . 1.1)))
|
||||||
|
(set-face-attribute (car face) nil :font "FiraCode Nerd Font" :weight 'medium :height (cdr face)))
|
||||||
|
(set-face-attribute 'org-block nil :foreground nil :inherit 'fixed-pitch)
|
||||||
|
(set-face-attribute 'org-table nil :inherit 'fixed-pitch)
|
||||||
|
(set-face-attribute 'org-formula nil :inherit 'fixed-pitch)
|
||||||
|
(set-face-attribute 'org-code nil :inherit '(shadow fixed-pitch))
|
||||||
|
(set-face-attribute 'org-verbatim nil :inherit '(shadow fixed-pitch))
|
||||||
|
(set-face-attribute 'org-special-keyword nil :inherit '(font-lock-comment-face fixed-pitch))
|
||||||
|
(set-face-attribute 'org-meta-line nil :inherit '(font-lock-comment-face fixed-pitch))
|
||||||
|
(set-face-attribute 'org-checkbox nil :inherit 'fixed-pitch)
|
||||||
|
|
||||||
|
|
||||||
|
;; Misc settings
|
||||||
(menu-bar-mode -1) ; Disable menubar
|
(menu-bar-mode -1) ; Disable menubar
|
||||||
(scroll-bar-mode -1) ; Disable visible scrollbar
|
(scroll-bar-mode -1) ; Disable visible scrollbar
|
||||||
(tool-bar-mode -1) ; Disable toolbar
|
(tool-bar-mode -1) ; Disable toolbar
|
||||||
|
Loading…
x
Reference in New Issue
Block a user