366 lines
11 KiB
Org Mode
366 lines
11 KiB
Org Mode
#+auto_tangle:
|
|
|
|
* Emacs config
|
|
|
|
** Packages initialization
|
|
|
|
Here, we're initializing MELPA, as well as package.el and use-package.
|
|
|
|
#+begin_src emacs-lisp
|
|
(require 'package)
|
|
(add-to-list 'package-archives '("melpa" . "https://melpa.org/packages/") t)
|
|
;; Comment/uncomment this line to enable MELPA Stable if desired. See `package-archive-priorities`
|
|
;; and `package-pinned-packages`. Most users will not need or want to do this.
|
|
;;(add-to-list 'package-archives '("melpa-stable" . "https://stable.melpa.org/packages/") t)
|
|
|
|
(unless package-archive-contents
|
|
(package-refresh-contents))
|
|
|
|
(unless (package-installed-p 'use-package)
|
|
(package-install 'use-package))
|
|
|
|
(require 'use-package)
|
|
(setq use-package-always-ensure t)
|
|
#+end_src
|
|
|
|
** General config
|
|
*** no-littering
|
|
|
|
no-littering is a useful package that allows to put all of the autosave files and temporary files in one directory (the files ending with ~ for instance)
|
|
#+begin_src emacs-lisp
|
|
(use-package no-littering)
|
|
#+end_src
|
|
|
|
*** Minimal interface
|
|
|
|
We disable a lot of interface elements, to make the editor more minimal looking.
|
|
|
|
#+begin_src emacs-lisp
|
|
(setq inhibit-startup-message t)
|
|
(scroll-bar-mode -1)
|
|
(tool-bar-mode -1)
|
|
(tooltip-mode -1)
|
|
(set-fringe-mode 10)
|
|
(menu-bar-mode -1)
|
|
#+end_src
|
|
|
|
*** Match fish shell's path
|
|
#+begin_src emacs-lisp
|
|
(defun set-exec-path-from-shell-PATH ()
|
|
"Set up Emacs' `exec-path' and PATH environment variable to match
|
|
that used by the user's shell.
|
|
|
|
This is particularly useful under Mac OS X and macOS, where GUI
|
|
apps are not started from a shell."
|
|
(interactive)
|
|
(let ((path-from-shell (replace-regexp-in-string
|
|
"[ \t\n]*$" "" (shell-command-to-string
|
|
"/usr/bin/fish --login -c 'string join : $PATH'"
|
|
))))
|
|
(setenv "PATH" path-from-shell)
|
|
(setq exec-path (split-string path-from-shell path-separator))))
|
|
|
|
(set-exec-path-from-shell-PATH)
|
|
|
|
#+end_src
|
|
*** Bell
|
|
|
|
I don't like any visual or sound bell.
|
|
|
|
#+begin_src emacs-lisp
|
|
(setq ring-bell-function 'ignore)
|
|
#+end_src
|
|
*** Font
|
|
|
|
I use the default monospace font, as it allows me to configure it system wide and have everything coherent. We just make it bigger here for readability.
|
|
|
|
#+begin_src emacs-lisp
|
|
(set-face-attribute 'default nil :font "monospace" :height 125)
|
|
#+end_src
|
|
**** Ligatures
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package ligature
|
|
:config
|
|
(ligature-set-ligatures '(prog-mode tsx-ts-mode) '("--" "---" "==" "===" "!=" "!==" "=!="
|
|
"=:=" "=/=" "<=" ">=" "&&" "&&&" "&=" "++" "+++" "***" ";;" "!!"
|
|
"??" "???" "?:" "?." "?=" "<:" ":<" ":>" ">:" "<:<" "<>" "<<<" ">>>"
|
|
"<<" ">>" "||" "-|" "_|_" "|-" "||-" "|=" "||=" "##" "###" "####"
|
|
"#{" "#[" "]#" "#(" "#?" "#_" "#_(" "#:" "#!" "#=" "^=" "<$>" "<$"
|
|
"$>" "<+>" "<+" "+>" "<*>" "<*" "*>" "</" "</>" "/>" "<!--" "<#--"
|
|
"-->" "->" "->>" "<<-" "<-" "<=<" "=<<" "<<=" "<==" "<=>" "<==>"
|
|
"==>" "=>" "=>>" ">=>" ">>=" ">>-" ">-" "-<" "-<<" ">->" "<-<" "<-|"
|
|
"<=|" "|=>" "|->" "<->" "<~~" "<~" "<~>" "~~" "~~>" "~>" "~-" "-~"
|
|
"~@" "[||]" "|]" "[|" "|}" "{|" "[<" ">]" "|>" "<|" "||>" "<||"
|
|
"|||>" "<|||" "<|>" "..." ".." ".=" "..<" ".?" "::" ":::" ":=" "::="
|
|
":?" ":?>" "//" "///" "/*" "*/" "/=" "//=" "/==" "@_" "__" "???"
|
|
"<:<" ";;;"))
|
|
(global-ligature-mode t))
|
|
#+end_src
|
|
|
|
*** Visual mode
|
|
|
|
We turn on visual mode, so that lines can wrap nicely and do go beyond my Emacs buffer size.
|
|
|
|
#+begin_src emacs-lisp
|
|
(visual-line-mode t)
|
|
#+end_src
|
|
|
|
*** Theme
|
|
I use catppuccin as my theme, as I find it comfortable to work with (the Frappe flavor).
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package catppuccin-theme
|
|
:init
|
|
(setq catppuccin-flavor 'frappe)
|
|
:config
|
|
(load-theme 'catppuccin :no-confirm))
|
|
#+end_src
|
|
|
|
*** Modeline
|
|
|
|
I use doom-modeline as my modeline, as I find it really clean and minimal.
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package doom-modeline
|
|
:ensure t
|
|
:init (doom-modeline-mode 1)
|
|
:config
|
|
(setq doom-modeline-height 30)
|
|
(setq nerd-icons-font-family "monospace"))
|
|
#+end_src
|
|
|
|
*** Completion
|
|
|
|
I use vertico as my completion framework. It's minimal, fast and tells me all I need to know and even sorts by history.
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package vertico
|
|
:init
|
|
(vertico-mode)
|
|
|
|
;; Different scroll margin
|
|
;; (setq vertico-scroll-margin 0)
|
|
|
|
;; Show more candidates
|
|
;; (setq vertico-count 20)
|
|
|
|
;; Grow and shrink the Vertico minibuffer
|
|
(setq vertico-resize t)
|
|
|
|
;; Optionally enable cycling for `vertico-next' and `vertico-previous'.
|
|
(setq vertico-cycle t))
|
|
|
|
;; Persist history over Emacs restarts. Vertico sorts by history position.
|
|
(use-package savehist
|
|
:init
|
|
(savehist-mode))
|
|
|
|
;; A few more useful configurations...
|
|
(use-package emacs
|
|
:init
|
|
;; Add prompt indicator to `completing-read-multiple'.
|
|
;; We display [CRM<separator>], e.g., [CRM,] if the separator is a comma.
|
|
(defun crm-indicator (args)
|
|
(cons (format "[CRM%s] %s"
|
|
(replace-regexp-in-string
|
|
"\\`\\[.*?]\\*\\|\\[.*?]\\*\\'" ""
|
|
crm-separator)
|
|
(car args))
|
|
(cdr args)))
|
|
(advice-add #'completing-read-multiple :filter-args #'crm-indicator)
|
|
|
|
;; Do not allow the cursor in the minibuffer prompt
|
|
(setq minibuffer-prompt-properties
|
|
'(read-only t cursor-intangible t face minibuffer-prompt))
|
|
(add-hook 'minibuffer-setup-hook #'cursor-intangible-mode)
|
|
|
|
;; Support opening new minibuffers from inside existing minibuffers.
|
|
(setq enable-recursive-minibuffers t)
|
|
|
|
;; Emacs 28 and newer: Hide commands in M-x which do not work in the current
|
|
;; mode. Vertico commands are hidden in normal buffers. This setting is
|
|
;; useful beyond Vertico.
|
|
(setq read-extended-command-predicate #'command-completion-default-include-p))
|
|
|
|
;; Optionally use the `orderless' completion style.
|
|
(use-package orderless
|
|
:init
|
|
;; Configure a custom style dispatcher (see the Consult wiki)
|
|
;; (setq orderless-style-dispatchers '(+orderless-consult-dispatch orderless-affix-dispatch)
|
|
;; orderless-component-separator #'orderless-escapable-split-on-space)
|
|
(setq completion-styles '(orderless basic)
|
|
completion-category-defaults nil
|
|
completion-category-overrides '((file (styles partial-completion)))))
|
|
#+end_src
|
|
|
|
*** which-key
|
|
|
|
which-key is a nice little package that allows to have a minibuffer showing which keybinds are available under prefixes.
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package which-key
|
|
:config
|
|
(which-key-mode))
|
|
#+end_src
|
|
|
|
*** quelpa
|
|
|
|
quelpa is a package that allows to build packages from source.
|
|
|
|
#+begin_src emacs-lisp
|
|
(unless (package-installed-p 'quelpa)
|
|
(with-temp-buffer
|
|
(url-insert-file-contents "https://raw.githubusercontent.com/quelpa/quelpa/master/quelpa.el")
|
|
(eval-buffer)
|
|
(quelpa-self-upgrade)))
|
|
#+end_src
|
|
|
|
use-package integration with quelpa.
|
|
#+begin_src emacs-lisp
|
|
(quelpa
|
|
'(quelpa-use-package
|
|
:fetcher git
|
|
:url "https://github.com/quelpa/quelpa-use-package.git"))
|
|
(require 'quelpa-use-package)
|
|
#+end_src
|
|
|
|
*** Reload org config config on save
|
|
|
|
This allows to tangle automatically when saving the config. This is mostly for convenience.
|
|
#+begin_src emacs-lisp
|
|
(use-package org-auto-tangle
|
|
:hook (org-mode . org-auto-tangle-mode)
|
|
:config
|
|
(defun my/reload-config-on-save ()
|
|
(when (string-equal (buffer-file-name)
|
|
(expand-file-name "~/.emacs.d/config.org"))
|
|
(load-file (expand-file-name "~/.emacs.d/config.el"))))
|
|
(add-hook 'after-save-hook #'my/reload-config-on-save))
|
|
#+end_src
|
|
|
|
** Org mode
|
|
|
|
*** Pretty bullets and headlines
|
|
|
|
I use org-superstar-mode, as it makes headlines and bullets look really nice.
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package org-superstar
|
|
:hook (org-mode . org-superstar-mode))
|
|
#+end_src
|
|
|
|
** Programming
|
|
*** LSP
|
|
#+begin_src emacs-lisp
|
|
(defun my-lsp-mode-setup ()
|
|
"Enable lsp-mode except in org-mode and emacs-lisp-mode."
|
|
(unless (or (derived-mode-p 'org-mode)
|
|
(derived-mode-p 'emacs-lisp-mode))
|
|
(lsp)))
|
|
|
|
(use-package lsp-mode
|
|
:hook (prog-mode . my-lsp-mode-setup)
|
|
(lsp-mode . lsp-enable-which-key-integration)
|
|
:init
|
|
(setq lsp-keymap-prefix "C-c l")
|
|
(setq read-process-output-max (* 1024 1024))
|
|
(setq gc-cons-threshold 100000000))
|
|
(use-package lsp-ui)
|
|
#+end_src
|
|
|
|
*** Projectile
|
|
#+begin_src emacs-lisp
|
|
(use-package projectile
|
|
:config
|
|
(projectile-mode +1)
|
|
(setq projectile-project-search-path '("~/projects"))
|
|
:bind
|
|
("C-c p" . 'projectile-command-map))
|
|
#+end_src
|
|
*** Autocompletion
|
|
#+begin_src emacs-lisp
|
|
(use-package company
|
|
:config
|
|
(setq company-idle-delay 0))
|
|
#+end_src
|
|
|
|
*** Snippets
|
|
#+begin_src emacs-lisp
|
|
(use-package yasnippet
|
|
:ensure t
|
|
:diminish yas-minor-mode
|
|
:hook (prog-mode . yas-minor-mode)
|
|
:bind (:map yas-minor-mode-map
|
|
("C-c C-e" . yas-expand)))
|
|
#+end_src
|
|
*** Magit
|
|
|
|
Magit is a git client in Emacs.
|
|
#+begin_src emacs-lisp
|
|
(use-package magit)
|
|
#+end_src
|
|
*** Languages
|
|
|
|
**** Rust
|
|
#+begin_src emacs-lisp
|
|
(use-package rust-mode
|
|
:init
|
|
(setq rust-format-on-save t))
|
|
#+end_src
|
|
|
|
**** Typst
|
|
#+begin_src emacs-lisp
|
|
(use-package typst-ts-mode
|
|
:quelpa (typst-ts-mode :fetcher git :url "https://git.sr.ht/~meow_king/typst-ts-mode" :files ("*.el"))
|
|
:custom
|
|
(typst-ts-mode-grammar-location (expand-file-name "tree-sitter/libtree-sitter-typst.so" user-emacs-directory)))
|
|
#+end_src
|
|
|
|
**** tree-sitter
|
|
#+begin_src emacs-lisp
|
|
(setq treesit-language-source-alist
|
|
'((bash "https://github.com/tree-sitter/tree-sitter-bash")
|
|
(cmake "https://github.com/uyha/tree-sitter-cmake")
|
|
(css "https://github.com/tree-sitter/tree-sitter-css")
|
|
(elisp "https://github.com/Wilfred/tree-sitter-elisp")
|
|
(go "https://github.com/tree-sitter/tree-sitter-go")
|
|
(html "https://github.com/tree-sitter/tree-sitter-html")
|
|
(javascript "https://github.com/tree-sitter/tree-sitter-javascript" "master" "src")
|
|
(json "https://github.com/tree-sitter/tree-sitter-json")
|
|
(make "https://github.com/alemuller/tree-sitter-make")
|
|
(markdown "https://github.com/ikatyang/tree-sitter-markdown")
|
|
(python "https://github.com/tree-sitter/tree-sitter-python")
|
|
(toml "https://github.com/tree-sitter/tree-sitter-toml")
|
|
(tsx "https://github.com/tree-sitter/tree-sitter-typescript" "master" "tsx/src")
|
|
(typescript "https://github.com/tree-sitter/tree-sitter-typescript" "master" "typescript/src")
|
|
(typst "https://github.com/uben0/tree-sitter-typst")
|
|
(yaml "https://github.com/ikatyang/tree-sitter-yaml")))
|
|
|
|
(add-to-list 'auto-mode-alist '("\\.ts\\'" . tsx-ts-mode))
|
|
(add-to-list 'auto-mode-alist '("\\.tsx\\'" . tsx-ts-mode))
|
|
#+end_src
|
|
|
|
#+begin_src sh
|
|
npm install -g typescript-language-server
|
|
#+end_src
|
|
|
|
**** Alapheia
|
|
#+begin_src emacs-lisp
|
|
(use-package apheleia
|
|
:ensure t
|
|
:config
|
|
(apheleia-global-mode +1)
|
|
(setf (alist-get 'prettier apheleia-formatters)
|
|
'(npx "prettier" file))
|
|
(setf (alist-get 'prettier-typescript apheleia-formatters)
|
|
'(npx "prettier" file)))
|
|
(use-package dtrt-indent)
|
|
#+end_src
|
|
|
|
**** expand-region
|
|
|
|
#+begin_src emacs-lisp
|
|
(use-package expand-region
|
|
:bind ("C-=" . er/expand-region))
|
|
#+end_src
|