home/natto/emacs: minor changes
Signed-off-by: Amneesh Singh <natto@weirdnatto.in>
This commit is contained in:
		@@ -1,13 +1,13 @@
 | 
			
		||||
#+TITLE: My Emacs Configuration
 | 
			
		||||
#+AUTHOR: Amneesh Singh
 | 
			
		||||
#+PROPERTY: header-args:emacs-lisp :tangle yes
 | 
			
		||||
#+PROPERTY: header-args :emacs-lisp :tangle yes
 | 
			
		||||
 | 
			
		||||
* Settings
 | 
			
		||||
** Setting the default face
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
 ; -*- lexical-binding: t; -*-
 | 
			
		||||
(set-frame-font "Fira Code 13" nil t)
 | 
			
		||||
;(add-to-list 'default-frame-alist '(font . "Fira Code-13"))
 | 
			
		||||
(add-to-list 'default-frame-alist '(font . "Fira Code-13"))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Some mode settings based on personal preferences
 | 
			
		||||
@@ -54,11 +54,14 @@
 | 
			
		||||
(add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/"))
 | 
			
		||||
(package-initialize)
 | 
			
		||||
(require 'use-package)
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
*** Profiling
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package benchmark-init
 | 
			
		||||
  :ensure t
 | 
			
		||||
  :config
 | 
			
		||||
  ;; To disable collection of benchmark data after init is done.
 | 
			
		||||
  (add-hook 'after-init-hook 'benchmark-init/deactivate))
 | 
			
		||||
  :init (benchmark-init/deactivate))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Visual packages
 | 
			
		||||
@@ -74,13 +77,15 @@
 | 
			
		||||
(use-package catppuccin-theme
 | 
			
		||||
  :config
 | 
			
		||||
  (load-theme 'catppuccin t)
 | 
			
		||||
  (setq dark-theme t))
 | 
			
		||||
  :custom
 | 
			
		||||
  (dark-theme t))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Configure Selectrum
 | 
			
		||||
Enable selectrum
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package selectrum
 | 
			
		||||
  :defer t
 | 
			
		||||
  :config
 | 
			
		||||
  (selectrum-mode +1))
 | 
			
		||||
#+end_src
 | 
			
		||||
@@ -130,7 +135,6 @@ Add selectrum-prescient
 | 
			
		||||
  (evil-mode 1))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
*** Configure undo tree
 | 
			
		||||
To undo and redo easily like vi
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
@@ -151,7 +155,10 @@ To undo and redo easily like vi
 | 
			
		||||
** Treemacs
 | 
			
		||||
*** Configure treemacs
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package treemacs)
 | 
			
		||||
(use-package treemacs
 | 
			
		||||
  :defer t
 | 
			
		||||
  :config
 | 
			
		||||
  (treemacs-project-follow-mode))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
@@ -165,12 +172,14 @@ To undo and redo easily like vi
 | 
			
		||||
*** Configure lsp-mode
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package lsp-mode
 | 
			
		||||
  :defer t
 | 
			
		||||
  :commands lsp)
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
*** Configure lsp-ui
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package lsp-ui
 | 
			
		||||
  :defer t
 | 
			
		||||
  :init
 | 
			
		||||
  (setq lsp-ui-doc-delay 1.0
 | 
			
		||||
        lsp-ui-doc-show-with-mouse t
 | 
			
		||||
@@ -178,22 +187,22 @@ To undo and redo easily like vi
 | 
			
		||||
        lsp-ui-doc-show-with-cursor t)
 | 
			
		||||
  :config
 | 
			
		||||
  (lsp-ui-peek-enable 1)
 | 
			
		||||
  (lsp-ui-doc-enable 1))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
*** Language specific LSP packages
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package lsp-haskell)
 | 
			
		||||
  (lsp-ui-doc-enable 1)
 | 
			
		||||
  :hook (lsp-mode . lsp-ui-mode))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
*** Configure flycheck
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package flycheck)
 | 
			
		||||
(use-package flycheck
 | 
			
		||||
  :defer t)
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
*** Configure dap-mode
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package dap-mode)
 | 
			
		||||
(use-package dap-mode
 | 
			
		||||
  :defer t
 | 
			
		||||
  :hook ((lsp-mode . dap-mode)
 | 
			
		||||
         (lsp-mode . dap-ui-mode)))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Company
 | 
			
		||||
@@ -205,7 +214,8 @@ For autocomplete
 | 
			
		||||
  :config
 | 
			
		||||
  (add-to-list 'company-backends 'company-dabbrev)
 | 
			
		||||
  (setq company-backends (append '(company-files) (remove 'company-files company-backends)))
 | 
			
		||||
  (company-mode 1))
 | 
			
		||||
  :hook (after-init . global-company-mode))
 | 
			
		||||
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
*** Configure company-quickhelp
 | 
			
		||||
@@ -230,31 +240,30 @@ For autocomplete
 | 
			
		||||
** Direnv
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package direnv
 | 
			
		||||
 :defer t
 | 
			
		||||
 :config
 | 
			
		||||
 (direnv-mode))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** STM32
 | 
			
		||||
** Languages
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package stm32-emacs)
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Lang support
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package haskell-mode)
 | 
			
		||||
(use-package lsp-latex)
 | 
			
		||||
(use-package rustic)
 | 
			
		||||
(use-package typescript-mode)
 | 
			
		||||
(use-package yuck-mode)
 | 
			
		||||
(use-package wgsl-mode)
 | 
			
		||||
(use-package lsp-haskell
 | 
			
		||||
  :mode "\\.hs\\'")
 | 
			
		||||
(use-package lsp-latex
 | 
			
		||||
  :mode "\\.tex\\'")
 | 
			
		||||
(use-package rustic
 | 
			
		||||
  :mode "\\.rs\\'")
 | 
			
		||||
(use-package typescript-mode
 | 
			
		||||
  :mode ("\\.ts\\'" "\\.tsx\\'"))
 | 
			
		||||
(use-package wgsl-mode
 | 
			
		||||
  :mode "\\.wgsl\\'")
 | 
			
		||||
(use-package nix-mode
 | 
			
		||||
  :mode "\\.nix\\'")
 | 
			
		||||
(use-package hcl-mode
 | 
			
		||||
  :mode
 | 
			
		||||
  "\\.hcl\\'"
 | 
			
		||||
  "\\.nomad\\'")
 | 
			
		||||
(use-package go-mode)
 | 
			
		||||
(use-package go-mode
 | 
			
		||||
  :mode "\\.go\\'")
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Magit
 | 
			
		||||
@@ -262,8 +271,8 @@ For autocomplete
 | 
			
		||||
(use-package magit :defer t)
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
* VTerm
 | 
			
		||||
** Configure vterm
 | 
			
		||||
** VTerm
 | 
			
		||||
*** Configure vterm
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package vterm
 | 
			
		||||
  :config
 | 
			
		||||
@@ -288,17 +297,27 @@ For autocomplete
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Centaur Tabs
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
Do not use centaur tabs for now
 | 
			
		||||
#+begin_src emacs-lisp :tangle no
 | 
			
		||||
(use-package centaur-tabs
 | 
			
		||||
  :defer t
 | 
			
		||||
  :custom
 | 
			
		||||
  (centaur-tabs-style "rounded")
 | 
			
		||||
	(centaur-tabs-height 18)
 | 
			
		||||
	(centaur-tabs-set-modified-marker t)
 | 
			
		||||
	(centaur-tabs-set-icons t)
 | 
			
		||||
  :config
 | 
			
		||||
  (setq centaur-tabs-style "rounded"
 | 
			
		||||
	centaur-tabs-height 18
 | 
			
		||||
	centaur-tabs-set-modified-marker t
 | 
			
		||||
	centaur-tabs-set-icons t)
 | 
			
		||||
  (centaur-tabs-mode t)
 | 
			
		||||
  (centaur-tabs-group-by-projectile-project)
 | 
			
		||||
  (centaur-tabs-mode nil)
 | 
			
		||||
  (set-face-attribute 'tab-line nil :inherit 'centaur-tabs-unselected)
 | 
			
		||||
  (centaur-tabs-headline-match))
 | 
			
		||||
  (centaur-tabs-headline-match)
 | 
			
		||||
  :bind
 | 
			
		||||
  (:map evil-normal-state-map
 | 
			
		||||
    ("M-," . centaur-tabs-forward)
 | 
			
		||||
    ("M-." . centaur-tabs-backward))
 | 
			
		||||
  (:map evil-motion-state-map
 | 
			
		||||
    ("M-," . centaur-tabs-forward)
 | 
			
		||||
    ("M-." . centaur-tabs-backward)))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Misc packages
 | 
			
		||||
@@ -322,38 +341,38 @@ For autocomplete
 | 
			
		||||
(use-package flex-autopair)
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
* Org
 | 
			
		||||
** Org
 | 
			
		||||
** Add org-mode
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package org
 | 
			
		||||
  :after evil
 | 
			
		||||
  :defer t
 | 
			
		||||
  :after evil
 | 
			
		||||
  :config
 | 
			
		||||
  (setq evil-want-C-i-jump nil
 | 
			
		||||
        org-adapt-indentation t
 | 
			
		||||
        org-src-fontify-natively t
 | 
			
		||||
        org-src-strip-leading-and-trailing-blank-lines t
 | 
			
		||||
        org-src-preserve-indentation t
 | 
			
		||||
        org-src-tab-acts-natively t)
 | 
			
		||||
  (define-key org-mode-map (kbd "RET") 'org-return-and-maybe-indent)
 | 
			
		||||
  (evil-define-key 'normal org-mode-map (kbd "TAB") 'org-cycle))
 | 
			
		||||
  (evil-define-key 'normal org-mode-map (kbd "TAB") 'org-cycle)
 | 
			
		||||
  :custom
 | 
			
		||||
  (evil-want-C-i-jump nil)
 | 
			
		||||
  (org-adapt-indentation t)
 | 
			
		||||
  (org-src-fontify-natively t)
 | 
			
		||||
  (org-src-strip-leading-and-trailing-blank-lines t)
 | 
			
		||||
  (org-src-preserve-indentation t)
 | 
			
		||||
  (org-src-tab-acts-natively t))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Add org-bullets
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
 (use-package org-bullets
 | 
			
		||||
  :defer t
 | 
			
		||||
  :config
 | 
			
		||||
  (add-hook 'org-mode-hook (lambda () (org-bullets-mode 1))))
 | 
			
		||||
  :hook ((org-mode . org-bullets-mode)))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
** Babel and exports
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package htmlize :defer t)
 | 
			
		||||
(add-to-list 'org-latex-packages-alist '("" "minted"))
 | 
			
		||||
(setq org-latex-listings 'minted) 
 | 
			
		||||
 | 
			
		||||
(setq org-latex-pdf-process
 | 
			
		||||
(setq org-latex-listings 'minted
 | 
			
		||||
      org-latex-packages-alist '(("" "minted"))
 | 
			
		||||
      org-latex-pdf-process
 | 
			
		||||
      '("pdflatex -shell-escape -interaction nonstopmode -output-directory %o %f"
 | 
			
		||||
        "pdflatex -shell-escape -interaction nonstopmode -output-directory %o %f"
 | 
			
		||||
        "pdflatex -shell-escape -interaction nonstopmode -output-directory %o %f"))
 | 
			
		||||
@@ -363,10 +382,8 @@ For autocomplete
 | 
			
		||||
 | 
			
		||||
(org-babel-do-load-languages
 | 
			
		||||
 'org-babel-load-languages
 | 
			
		||||
 '((awk . t)
 | 
			
		||||
   (python . t)
 | 
			
		||||
 '((python . t)
 | 
			
		||||
   (C . t)
 | 
			
		||||
   (shell . t)
 | 
			
		||||
   (sql . t)
 | 
			
		||||
   (latex . t)))
 | 
			
		||||
#+end_src
 | 
			
		||||
@@ -385,8 +402,7 @@ For autocomplete
 | 
			
		||||
switched to doom modeline after using my own modeline for a while
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package doom-modeline
 | 
			
		||||
  :ensure t
 | 
			
		||||
  :hook (after-init . doom-modeline-mode))
 | 
			
		||||
  :init (doom-modeline-mode 1))
 | 
			
		||||
#+end_src
 | 
			
		||||
 | 
			
		||||
* Pop-up terminal
 | 
			
		||||
@@ -425,6 +441,7 @@ Compilation shortcuts for standalone files
 | 
			
		||||
           ("java" (concat "java " full))
 | 
			
		||||
           ("py" (concat "python " full))
 | 
			
		||||
           ("cpp" (concat "g++ " full " -o " file " && " file " && rm " file))
 | 
			
		||||
           ("cc" (concat "g++ " full " -o " file " && " file " && rm " file))
 | 
			
		||||
           ("hs" (concat "runhaskell " full))
 | 
			
		||||
           ("sh" (concat "sh " full))
 | 
			
		||||
           ("js" (concat "node " full))
 | 
			
		||||
@@ -455,7 +472,8 @@ not using this anymore
 | 
			
		||||
 | 
			
		||||
*** Misc binds
 | 
			
		||||
#+begin_src emacs-lisp
 | 
			
		||||
(use-package general)
 | 
			
		||||
(use-package general
 | 
			
		||||
  :ensure t)
 | 
			
		||||
 | 
			
		||||
(setq evil-states
 | 
			
		||||
  '(visual normal motion))
 | 
			
		||||
@@ -475,18 +493,16 @@ not using this anymore
 | 
			
		||||
    :keymaps '(global override vterm-mode-map)
 | 
			
		||||
    :states evil-states
 | 
			
		||||
    "M-o" 'treemacs
 | 
			
		||||
    "M-S-v" 'split-window-vertically
 | 
			
		||||
    "M-S-h" 'split-window-horizontally
 | 
			
		||||
    "M-s-v" 'split-window-vertically
 | 
			
		||||
    "M-s-h" 'split-window-horizontally
 | 
			
		||||
    "M-h" 'windmove-left
 | 
			
		||||
    "M-j" 'windmove-down
 | 
			
		||||
    "M-k" 'windmove-up
 | 
			
		||||
    "M-l" 'windmove-right
 | 
			
		||||
    "M-C-h" 'shrink-window-horizontally
 | 
			
		||||
    "M-C-j" 'enlarge-window-horizontally
 | 
			
		||||
    "M-C-k" 'shrink-window
 | 
			
		||||
    "M-C-l" 'enlarge-window
 | 
			
		||||
    "M-,"  'centaur-tabs-backward
 | 
			
		||||
    "M-."  'centaur-tabs-forward
 | 
			
		||||
    "M-C-l" 'enlarge-window-horizontally
 | 
			
		||||
    "M-C-j" 'shrink-window
 | 
			
		||||
    "M-C-k" 'enlarge-window
 | 
			
		||||
    "C-q"  'delete-window
 | 
			
		||||
    "M-C-S-q"  'kill-buffer-and-window
 | 
			
		||||
    "M-w"  'centaur-tabs--kill-this-buffer-dont-ask
 | 
			
		||||
@@ -505,6 +521,6 @@ not using this anymore
 | 
			
		||||
      "<f5>" (lambda () (interactive) (run-in-vterm (candrun))))
 | 
			
		||||
    (general-define-key
 | 
			
		||||
      :keymaps 'vterm-mode-map
 | 
			
		||||
      "<f2>" 'vterm-toggle-forward
 | 
			
		||||
      "<f3>" 'vterm-toggle-backward)))
 | 
			
		||||
      "<f3>" 'vterm-toggle-forward
 | 
			
		||||
      "<f2>" 'vterm-toggle-backward)))
 | 
			
		||||
#+end_src
 | 
			
		||||
 
 | 
			
		||||
@@ -1,2 +1,8 @@
 | 
			
		||||
(delete-file (expand-file-name "~/.emacs.d/config.el"))
 | 
			
		||||
(org-babel-load-file (expand-file-name "~/.emacs.d/config.org"))
 | 
			
		||||
(defconst config-org (expand-file-name "config.org" user-emacs-directory))
 | 
			
		||||
(defconst config-el (expand-file-name "config.el" user-emacs-directory))
 | 
			
		||||
 | 
			
		||||
(unless (file-exists-p config-el)
 | 
			
		||||
  (require 'org)
 | 
			
		||||
  (org-babel-tangle-file config-org config-el))
 | 
			
		||||
 | 
			
		||||
(load-file config-el)
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user