aboutsummaryrefslogtreecommitdiff
path: root/home-manager/programs/emacs
diff options
context:
space:
mode:
Diffstat (limited to 'home-manager/programs/emacs')
-rw-r--r--home-manager/programs/emacs/default.nix29
-rw-r--r--home-manager/programs/emacs/early-init.el5
-rw-r--r--home-manager/programs/emacs/init.el639
3 files changed, 673 insertions, 0 deletions
diff --git a/home-manager/programs/emacs/default.nix b/home-manager/programs/emacs/default.nix
new file mode 100644
index 0000000..d74c93a
--- /dev/null
+++ b/home-manager/programs/emacs/default.nix
@@ -0,0 +1,29 @@
+{ pkgs, ... }:
+let
+ service = {
+ client = {
+ enable = true;
+ arguments = [ "-c" "-a emacs" ];
+ };
+ defaultEditor = true;
+ startWithUserSession = "graphical";
+ package = pkgs.emacs-gtk;
+ };
+ configs = {
+ "emacs/init.el".text = builtins.readFile ./init.el;
+ "emacs/early-init.el".text = builtins.readFile ./init.el;
+ };
+in
+{
+ services.emacs = {
+ enable = true;
+ inherit (service);
+ };
+ programs.emacs = {
+ enable = true;
+ inherit (service) package;
+ };
+ xdg.configFile = {
+ inherit (configs);
+ };
+}
diff --git a/home-manager/programs/emacs/early-init.el b/home-manager/programs/emacs/early-init.el
new file mode 100644
index 0000000..00e3392
--- /dev/null
+++ b/home-manager/programs/emacs/early-init.el
@@ -0,0 +1,5 @@
+(setq package-enable-at-startup nil)
+
+(menu-bar-mode -1)
+(tool-bar-mode -1)
+(scroll-bar-mode -1)
diff --git a/home-manager/programs/emacs/init.el b/home-manager/programs/emacs/init.el
new file mode 100644
index 0000000..8e39bb2
--- /dev/null
+++ b/home-manager/programs/emacs/init.el
@@ -0,0 +1,639 @@
+
+;; Elpaca package manager
+(defvar elpaca-installer-version 0.5)
+(defvar elpaca-directory (expand-file-name "elpaca/" user-emacs-directory))
+(defvar elpaca-builds-directory (expand-file-name "builds/" elpaca-directory))
+(defvar elpaca-repos-directory (expand-file-name "repos/" elpaca-directory))
+(defvar elpaca-order '(elpaca :repo "https://github.com/progfolio/elpaca.git"
+ :ref nil
+ :files (:defaults (:exclude "extensions"))
+ :build (:not elpaca--activate-package)))
+(let* ((repo (expand-file-name "elpaca/" elpaca-repos-directory))
+ (build (expand-file-name "elpaca/" elpaca-builds-directory))
+ (order (cdr elpaca-order))
+ (default-directory repo))
+ (add-to-list 'load-path (if (file-exists-p build) build repo))
+ (unless (file-exists-p repo)
+ (make-directory repo t)
+ (when (< emacs-major-version 28) (require 'subr-x))
+ (condition-case-unless-debug err
+ (if-let ((buffer (pop-to-buffer-same-window "*elpaca-bootstrap*"))
+ ((zerop (call-process "git" nil buffer t "clone"
+ (plist-get order :repo) repo)))
+ ((zerop (call-process "git" nil buffer t "checkout"
+ (or (plist-get order :ref) "--"))))
+ (emacs (concat invocation-directory invocation-name))
+ ((zerop (call-process emacs nil buffer nil "-Q" "-L" "." "--batch"
+ "--eval" "(byte-recompile-directory \".\" 0 'force)")))
+ ((require 'elpaca))
+ ((elpaca-generate-autoloads "elpaca" repo)))
+ (progn (message "%s" (buffer-string)) (kill-buffer buffer))
+ (error "%s" (with-current-buffer buffer (buffer-string))))
+ ((error) (warn "%s" err) (delete-directory repo 'recursive))))
+ (unless (require 'elpaca-autoloads nil t)
+ (require 'elpaca)
+ (elpaca-generate-autoloads "elpaca" repo)
+ (load "./elpaca-autoloads")))
+(add-hook 'after-init-hook #'elpaca-process-queues)
+(elpaca `(,@elpaca-order))
+
+(elpaca elpaca-use-package
+ (elpaca-use-package-mode)
+ (setq elpaca-use-package-by-default t))
+
+(elpaca-wait)
+
+;;When installing a package which modifies a form used at the top-level
+;;(e.g. a package which adds a use-package key word),
+;;use `elpaca-wait' to block until that package has been installed/configured.
+;;For example:
+;;(elpaca-wait)
+
+;;Turns off elpaca-use-package-mode current declartion
+;;Note this will cause the declaration to be interpreted immediately (not deferred).
+;;Useful for configuring built-in emacs features.
+(use-package emacs :elpaca nil :config (setq ring-bell-function #'ignore))
+
+;; Don't install anything. Defer execution of BODY
+;; (elpaca nil (message "deferred"))
+
+;; Evil
+;; (use-package evil
+;; :init
+;; (setq evil-want-integration t)
+;; (setq evil-want-keybinding nil)
+;; (setq evil-split-window-below t)
+;; (setq evil-vsplit-window-right t)
+;; (evil-mode))
+;; (use-package evil-collection
+;; :after evil
+;; :config
+;; (setq evil-collection-mode-list '(dashboard dired ibuffer))
+;; (evil-collection-init))
+
+;; Meow
+(use-package meow
+ :config
+(defun meow-setup ()
+ (setq meow-use-clipboard t)
+ (setq meow-cheatsheet-layout meow-cheatsheet-layout-qwerty)
+ (meow-motion-overwrite-define-key
+ '("j" . meow-next)
+ '("k" . meow-prev)
+ '("<escape>" . ignore))
+ (meow-leader-define-key
+ ;; SPC j/k will run the original command in MOTION state.
+ '("j" . "H-j")
+ '("k" . "H-k")
+ ;; Use SPC (0-9) for digit arguments.
+ '("1" . meow-digit-argument)
+ '("2" . meow-digit-argument)
+ '("3" . meow-digit-argument)
+ '("4" . meow-digit-argument)
+ '("5" . meow-digit-argument)
+ '("6" . meow-digit-argument)
+ '("7" . meow-digit-argument)
+ '("8" . meow-digit-argument)
+ '("9" . meow-digit-argument)
+ '("0" . meow-digit-argument)
+ '("/" . meow-keypad-describe-key)
+ '("?" . meow-cheatsheet)
+ '("bk" . kill-this-buffer))
+ (meow-normal-define-key
+ '("0" . meow-expand-0)
+ '("9" . meow-expand-9)
+ '("8" . meow-expand-8)
+ '("7" . meow-expand-7)
+ '("6" . meow-expand-6)
+ '("5" . meow-expand-5)
+ '("4" . meow-expand-4)
+ '("3" . meow-expand-3)
+ '("2" . meow-expand-2)
+ '("1" . meow-expand-1)
+ '("-" . negative-argument)
+ '(";" . meow-reverse)
+ '("," . meow-inner-of-thing)
+ '("." . meow-bounds-of-thing)
+ '("[" . meow-beginning-of-thing)
+ '("]" . meow-end-of-thing)
+ '("a" . meow-append)
+ '("A" . meow-open-below)
+ '("b" . meow-back-word)
+ '("B" . meow-back-symbol)
+ '("c" . meow-change)
+ '("d" . meow-delete)
+ '("D" . meow-backward-delete)
+ '("e" . meow-next-word)
+ '("E" . meow-next-symbol)
+ '("f" . meow-find)
+ '("g" . meow-cancel-selection)
+ '("G" . meow-grab)
+ '("h" . meow-left)
+ '("H" . meow-left-expand)
+ '("i" . meow-insert)
+ '("I" . meow-open-above)
+ '("j" . meow-next)
+ '("J" . meow-next-expand)
+ '("k" . meow-prev)
+ '("K" . meow-prev-expand)
+ '("l" . meow-right)
+ '("L" . meow-right-expand)
+ '("m" . meow-join)
+ '("n" . meow-search)
+ '("o" . meow-block)
+ '("O" . meow-to-block)
+ '("p" . meow-yank)
+ '("q" . meow-quit)
+ '("Q" . meow-goto-line)
+ '("r" . meow-replace)
+ '("R" . meow-swap-grab)
+ '("s" . meow-kill)
+ '("t" . meow-till)
+ '("u" . meow-undo)
+ '("U" . meow-undo-in-selection)
+ '("v" . meow-visit)
+ '("w" . meow-mark-word)
+ '("W" . meow-mark-symbol)
+ '("x" . meow-line)
+ '("X" . meow-goto-line)
+ '("y" . meow-save)
+ '("Y" . meow-sync-grab)
+ '("z" . meow-pop-selection)
+ '("'" . repeat)
+ '("<escape>" . ignore)))
+(meow-setup)
+(meow-global-mode 1))
+
+;; General Keybindings
+(use-package general
+ :config
+
+ ;; SPC as the global leader key
+ (general-create-definer spl3g/leader-keys
+ :prefix "C-c")
+
+ (spl3g/leader-keys
+ ;; Buffers
+ "b" '(:ignore t :wk "Buffer")
+ "bi" '(ibuffer :wk "ibuffer")
+ "bk" '(kill-this-buffer :wk "Kill this buffer")
+ "bn" '(next-buffer :wk "Next buffer")
+ "bp" '(previous-buffer :wk "Previous buffer")
+ "br" '(revert-buffer :wk "Reload buffer")
+ "," '(consult-buffer :wk "Switch to buffer")
+ "." '(find-file :wk "Find file")
+ ;; Splits
+ "w" '(:ignore t :wk "Evil splits")
+ "wv" '(evil-window-vsplit :wk "Split vertical")
+ "ws" '(evil-window-split :wk "Split")
+ "ww" '(evil-window-next :wk "Cycle throug windows")
+ "wc" '(evil-window-delete :wk "Close window")
+ "wd" '(evil-window-delete :wk "Close window")
+ ;; Files
+ "f" '(:ignore t :wk "Files")
+ "fr" '(consult-recent-file :wk "Resent files")
+ "fc" '((lambda () (interactive) (find-file "~/.config/emacs/init.el")) :wk "Edit emacs config")
+ "fu" '(sudo-edit-find-file :wk "Sudo find file")
+ "fU" '(sudo-edit :wk "Sudo edit file")
+ ;; Quiting
+ "q" '(:ignore t :wk "Quiting")
+ "qq" '(:ignore t :wk "Quit TBD")
+ "qr" '(:ignore t :wk "Restart TBD")
+ "qe" '(eval-buffer :wk "Eval buffer")
+ "r" '(reload-init-file :wk "Reload config")
+ "l" '(lsp-keymap-prefix :wk "LSP")))
+(elpaca-wait)
+
+;; Which key
+(use-package which-key
+ :init
+ (which-key-mode 1)
+ :config
+ (setq which-key-side-window-location 'bottom
+ which-key-sort-order #'which-key-key-order-alpha
+ which-key-sort-uppercase-first nil
+ which-key-add-column-padding 1
+ which-key-max-display-columns nil
+ which-key-side-window-slot -10
+ which-key-side-window-max-height 0.25
+ which-key-idle-deley 0.8
+ which-key-max-description-length 25
+ which-key-allow-imprecise-window-fit t
+ which-key-separator " -> "))
+
+
+
+
+;; Vertico
+(use-package vertico
+ :init
+ (vertico-mode))
+
+;; For persistent history
+(savehist-mode 1)
+;; Idk what it means but they said that i need it
+(use-package emacs :elpaca nil
+ :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)
+
+ ;; Emacs 28: Hide commands in M-x which do not work in the current mode.
+ ;; Vertico commands are hidden in normal buffers.
+ ;; (setq read-extended-command-predicate
+ ;; #'command-completion-default-include-p)
+
+ ;; Enable recursive minibuffers
+ (setq enable-recursive-minibuffers t))
+;; Orderless
+(use-package orderless
+ :init
+ (setq completion-styles '(orderless basic)
+ completion-category-defaults nil
+ completion-category-overrides '((file (styles partial-completion)))))
+(use-package marginalia
+ :bind (:map minibuffer-local-map
+ ("M-A" . marginalia-cycle))
+ :init
+ (marginalia-mode))
+
+;; Consult
+(use-package consult
+ ;; Replace bindings. Lazily loaded due by `use-package'.
+ :bind (;; C-c bindings in `mode-specific-map'
+ ("C-c M-x" . consult-mode-command)
+ ("C-c h" . consult-history)
+ ("C-c k" . consult-kmacro)
+ ("C-c m" . consult-man)
+ ("C-c i" . consult-info)
+ ([remap Info-search] . consult-info)
+ ;; C-x bindings in `ctl-x-map'
+ ("C-x M-:" . consult-complex-command) ;; orig. repeat-complex-command
+ ("C-x b" . consult-buffer) ;; orig. switch-to-buffer
+ ("C-x 4 b" . consult-buffer-other-window) ;; orig. switch-to-buffer-other-window
+ ("C-x 5 b" . consult-buffer-other-frame) ;; orig. switch-to-buffer-other-frame
+ ("C-x r b" . consult-bookmark) ;; orig. bookmark-jump
+ ("C-x p b" . consult-project-buffer) ;; orig. project-switch-to-buffer
+ ;; Custom M-# bindings for fast register access
+ ("M-#" . consult-register-load)
+ ("M-'" . consult-register-store) ;; orig. abbrev-prefix-mark (unrelated)
+ ("C-M-#" . consult-register)
+ ;; Other custom bindings
+ ("M-y" . consult-yank-pop) ;; orig. yank-pop
+ ;; M-g bindings in `goto-map'
+ ("M-g e" . consult-compile-error)
+ ("M-g f" . consult-flymake) ;; Alternative: consult-flycheck
+ ("M-g g" . consult-goto-line) ;; orig. goto-line
+ ("M-g M-g" . consult-goto-line) ;; orig. goto-line
+ ("M-g o" . consult-outline) ;; Alternative: consult-org-heading
+ ("M-g m" . consult-mark)
+ ("M-g k" . consult-global-mark)
+ ("M-g i" . consult-imenu)
+ ("M-g I" . consult-imenu-multi)
+ ;; M-s bindings in `search-map'
+ ("M-s d" . consult-find)
+ ("M-s D" . consult-locate)
+ ("M-s g" . consult-grep)
+ ("M-s G" . consult-git-grep)
+ ("M-s r" . consult-ripgrep)
+ ("M-s l" . consult-line)
+ ("M-s L" . consult-line-multi)
+ ("M-s k" . consult-keep-lines)
+ ("M-s u" . consult-focus-lines)
+ ;; Isearch integration
+ ("M-s e" . consult-isearch-history)
+ :map isearch-mode-map
+ ("M-e" . consult-isearch-history) ;; orig. isearch-edit-string
+ ("M-s e" . consult-isearch-history) ;; orig. isearch-edit-string
+ ("M-s l" . consult-line) ;; needed by consult-line to detect isearch
+ ("M-s L" . consult-line-multi) ;; needed by consult-line to detect isearch
+ ;; Minibuffer history
+ :map minibuffer-local-map
+ ("M-s" . consult-history) ;; orig. next-matching-history-element
+ ("M-r" . consult-history)) ;; orig. previous-matching-history-element
+
+ ;; Enable automatic preview at point in the *Completions* buffer. This is
+ ;; relevant when you use the default completion UI.
+ :hook (completion-list-mode . consult-preview-at-point-mode)
+
+ ;; The :init configuration is always executed (Not lazy)
+ :init
+
+ ;; Optionally configure the register formatting. This improves the register
+ ;; preview for `consult-register', `consult-register-load',
+ ;; `consult-register-store' and the Emacs built-ins.
+ (setq register-preview-delay 0.5
+ register-preview-function #'consult-register-format)
+
+ ;; Optionally tweak the register preview window.
+ ;; This adds thin lines, sorting and hides the mode line of the window.
+ (advice-add #'register-preview :override #'consult-register-window)
+
+ ;; Use Consult to select xref locations with preview
+ (setq xref-show-xrefs-function #'consult-xref
+ xref-show-definitions-function #'consult-xref)
+
+ ;; Configure other variables and modes in the :config section,
+ ;; after lazily loading the package.
+ :config
+
+ ;; Optionally configure preview. The default value
+ ;; is 'any, such that any key triggers the preview.
+ ;; (setq consult-preview-key 'any)
+ ;; (setq consult-preview-key "M-.")
+ ;; (setq consult-preview-key '("S-<down>" "S-<up>"))
+ ;; For some commands and buffer sources it is useful to configure the
+ ;; :preview-key on a per-command basis using the `consult-customize' macro.
+ (consult-customize
+ consult-ripgrep consult-git-grep consult-grep
+ consult-bookmark consult-recent-file consult-xref
+ consult--source-bookmark consult--source-file-register
+ consult--source-recent-file consult--source-project-recent-file)
+ ;; :preview-key "M-."
+
+ ;; Optionally configure the narrowing key.
+ ;; Both < and C-+ work reasonably well.
+ (setq consult-narrow-key "<") ;; "C-+"
+
+ ;; Optionally make narrowing help available in the minibuffer.
+ ;; You may want to use `embark-prefix-help-command' or which-key instead.
+ ;; (define-key consult-narrow-map (vconcat consult-narrow-key "?") #'consult-narrow-help)
+
+ ;; By default `consult-project-function' uses `project-root' from project.el.
+ ;; Optionally configure a different project root function.
+ ;;;; 1. project.el (the default)
+ ;; (setq consult-project-function #'consult--default-project--function)
+ ;;;; 2. vc.el (vc-root-dir)
+ ;; (setq consult-project-function (lambda (_) (vc-root-dir)))
+ ;;;; 3. locate-dominating-file
+ ;; (setq consult-project-function (lambda (_) (locate-dominating-file "." ".git")))
+ ;;;; 4. projectile.el (projectile-project-root)
+ ;; (autoload 'projectile-project-root "projectile")
+ ;; (setq consult-project-function (lambda (_) (projectile-project-root)))
+ ;;;; 5. No project support
+ ;; (setq consult-project-function nil)
+)
+
+;; Hotfuzz
+;; (use-package hotfuzz
+;; :config
+;; (setq completion-styles '(hotfuzz))
+;; (setq completion-ignore-case t))
+
+;; Lsp
+(use-package lsp-mode
+ :hook
+ (python-mode . lsp)
+ (rust-mode . lsp)
+ (lsp-mode . lsp-enable-which-key-integration)
+ (sh-mode . lsp)
+ :commands lsp)
+(use-package lsp-pyright
+ :ensure t)
+(use-package lsp-ui
+ :hook (lsp-mode-hook . lsp-ui-mode)
+ :custom
+ (lsp-ui-peek-always-show t)
+ (lsp-ui-sideline-show-hover t)
+ (lsp-ui-doc-enable t))
+
+(use-package lsp-treemacs)
+
+;; Flycheck
+(use-package flycheck)
+
+;; Corfu + Cape
+(use-package corfu
+ :custom
+ (corfu-cycle t)
+ (corfu-auto t)
+ (corfu-preselect 'prompt)
+ :bind
+ (:map corfu-map
+ ("TAB" . corfu-next)
+ ([tab] . corfu-next)
+ ("S-TAB" . corfu-previous)
+ ([backtab] . corfu-previous))
+ :init
+ (global-corfu-mode))
+ ;;(use-package cape
+ ;; :bind (("C-c a f" . cape-file))
+ ;; :init
+ ;; (add-to-list 'completion-at-point-functions # 'cape-file)))
+(use-package cape
+ :init
+ (add-to-list 'completion-at-point-functions #'cape-file))
+(use-package emacs :elpaca nil
+ :init
+ (setq completion-cycle-threshold 3)
+ (setq tab-always-indent 'complete))
+
+;; Treemacs
+(use-package treemacs
+ :config
+ (setq treemacs-no-png-images t))
+(use-package treemacs-evil)
+(use-package treemacs-all-the-icons)
+
+;; Resent files
+(recentf-mode 1)
+(setq recentf-max-menu-items 25)
+(setq recentf-max-saved-items 50)
+
+;; Sudo
+(use-package sudo-edit)
+
+;; (defun sudo-find-file-hook ()
+;; (when (and (not (file-writable-p buffer-file-name))
+;; (y-or-n-p-with-timeout "File not writable. Open as root?" 2 t))
+;; (let ((obuf (current-buffer)))
+;; (sudo-edit)
+;; (unless (equal (current-buffer) obuf)
+;; (let)
+
+;; Parinfer
+(electric-pair-mode 1)
+
+;; NixOS
+(use-package nix-mode
+ :mode "(.nix)$")
+;; (use-package nix-drv-mode :elpaca nil
+;; :ensure nix-mode
+;; :mode ".drv")
+;; (use-package nix-shell :elpaca nil
+;; :ensure nix-mode
+;; :commands (nix-shell-unpack nix-shell-configure nix-shell-build))
+;; (use-package nix-repl :elpaca nil
+;; :ensure nix-mode
+;; :commands (nix-repl))
+
+;; Reload config
+(defun reload-init-file () (interactive)
+ (load-file user-init-file)
+ (load-file user-init-file))
+
+;; Magit
+(use-package magit)
+
+;; Fish
+(use-package fish-mode
+ :mode "(.fish)$")
+
+;; Rust
+(use-package rustic
+ :ensure
+ :bind (:map rustic-mode-map
+ ("M-j" . lsp-ui-imenu)
+ ("M-?" . lsp-find-references)
+ ("C-c C-c l" . flycheck-list-errors)
+ ("C-c C-c a" . lsp-execute-code-action)
+ ("C-c C-c r" . lsp-rename)
+ ("C-c C-c q" . lsp-workspace-restart)
+ ("C-c C-c Q" . lsp-workspace-shutdown)
+ ("C-c C-c s" . lsp-rust-analyzer-status))
+ :config
+ ;; uncomment for less flashiness
+ ;; (setq lsp-eldoc-hook nil)
+ ;; (setq lsp-enable-symbol-highlighting nil)
+ ;; (setq lsp-signature-auto-activate nil)
+
+ ;; comment to disable rustfmt on save
+ (setq rustic-format-on-save t)
+ (add-hook 'rustic-mode-hook 'rk/rustic-mode-hook))
+
+(defun rk/rustic-mode-hook ()
+ ;; so that run C-c C-c C-r works without having to confirm, but don't try to
+ ;; save rust buffers that are not file visiting. Once
+ ;; https://github.com/brotzeit/rustic/issues/253 has been resolved this should
+ ;; no longer be necessary.
+ (when buffer-file-name
+ (setq-local buffer-save-without-query t))
+ (add-hook 'before-save-hook 'lsp-format-buffer nil t))
+
+;; GUI tweaks
+;; Disable bars (no alcohol here.. maybe just a litle bit)
+(menu-bar-mode -1)
+(tool-bar-mode -1)
+(scroll-bar-mode -1)
+
+;; Display numbers
+(global-display-line-numbers-mode 1)
+(global-visual-line-mode t)
+
+;; Theme
+(use-package autothemer)
+(use-package catppuccin-theme
+ :ensure t
+ :config
+ (load-theme 'catppuccin t)
+ (setq catppuccin-flavor 'mocha)
+ (catppuccin-reload))
+
+;; Fonts
+(set-face-attribute 'default nil
+ :font "Source Code Pro"
+ :height 113
+ :weight 'medium)
+(set-face-attribute 'fixed-pitch nil
+ :font "Source Code Pro"
+ :height 113
+ :weight 'medium)
+(set-face-attribute 'variable-pitch nil
+ :font "Rubik"
+ :height 113
+ :weight 'medium)
+(set-face-attribute 'font-lock-comment-face nil
+ :slant 'italic)
+(set-face-attribute 'font-lock-keyword-face nil
+ :weight 'bold)
+
+;; Icons
+(use-package all-the-icons
+ :ensure t
+ :if (display-graphic-p))
+(use-package all-the-icons-dired
+ :hook (dired-mode . (lambda ()
+ all-the-icons-dired-mode t)))
+
+;; Modeline
+(use-package mood-line
+ :init
+ (mood-line-mode)
+ :config
+ (setq mood-line-glyph-alist mood-line-glyphs-unicode))
+
+;; Scrolling
+(use-package good-scroll
+ :init (good-scroll-mode))
+
+;; Dashboard
+(use-package dashboard
+ :init
+ (dashboard-setup-startup-hook)
+ :config
+ (setq initial-buffer-choice (lambda () (get-buffer-create "*dashboard*")))
+ (setq dashboard-banner-logo-title "Yep, it's emacs, not vim")
+ (setq dashboard-startup-banner 'logo)
+ (setq dashboard-center-content t))
+
+;; Vterm
+
+
+(custom-set-variables
+ ;; custom-set-variables was added by Custom.
+ ;; If you edit it by hand, you could mess it up, so be careful.
+ ;; Your init file should contain only one such instance.
+ ;; If there is more than one, they won't work right.
+ '(package-selected-packages '(nix-mode))
+ '(warning-suppress-types
+ '((comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp)
+ (comp))))
+(custom-set-faces)
+ ;; custom-set-faces was added by Custom.
+ ;; If you edit it by hand, you could mess it up, so be careful.
+ ;; Your init file should contain only one such instance.
+ ;; If there is more than one, they won't work right.
+
+ ;; custom-set-faces was added by Custom.
+ ;; If you edit it by hand, you could mess it up, so be careful.
+ ;; Your init file should contain only one such instance.
+ ;; If there is more than one, they won't work right.
+
+ ;; custom-set-faces was added by Custom.
+ ;; If you edit it by hand, you could mess it up, so be careful.
+ ;; Your init file should contain only one such instance.
+ ;; If there is more than one, they won't work right.
+
+ ;; custom-set-faces was added by Custom.
+ ;; If you edit it by hand, you could mess it up, so be careful.
+ ;; Your init file should contain only one such instance.
+ ;; If there is more than one, they won't work right.
+
+ ;; custom-set-faces was added by Custom.
+ ;; If you edit it by hand, you could mess it up, so be careful.
+ ;; Your init file should contain only one such instance.
+ ;; If there is more than one, they won't work right.
+