150 lines
5.5 KiB
EmacsLisp
150 lines
5.5 KiB
EmacsLisp
;;; $DOOMDIR/config.el -*- lexical-binding: t; -*-
|
|
|
|
;; Place your private configuration here! Remember, you do not need to run 'doom
|
|
;; sync' after modifying this file!
|
|
|
|
;; Some functionality uses this to identify you, e.g. GPG configuration, email
|
|
;; clients, file templates and snippets. It is optional.
|
|
(setq user-full-name "Max Regan"
|
|
user-mail-address "mgregan2@gmail.com")
|
|
|
|
;; Doom exposes five (optional) variables for controlling fonts in Doom:
|
|
;;
|
|
;; - `doom-font' -- the primary font to use
|
|
;; - `doom-variable-pitch-font' -- a non-monospace font (where applicable)
|
|
;; - `doom-big-font' -- used for `doom-big-font-mode'; use this for
|
|
;; presentations or streaming.
|
|
;; - `doom-unicode-font' -- for unicode glyphs
|
|
;; - `doom-serif-font' -- for the `fixed-pitch-serif' face
|
|
;;
|
|
;; See 'C-h v doom-font' for documentation and more examples of what they
|
|
;; accept. For example:
|
|
;;
|
|
;;(setq doom-font (font-spec :family "Fira Code" :size 12 :weight 'semi-light)
|
|
;; doom-variable-pitch-font (font-spec :family "Fira Sans" :size 13))
|
|
;;
|
|
;; If you or Emacs can't find your font, use 'M-x describe-font' to look them
|
|
;; up, `M-x eval-region' to execute elisp code, and 'M-x doom/reload-font' to
|
|
;; refresh your font settings. If Emacs still can't find your font, it likely
|
|
;; wasn't installed correctly. Font issues are rarely Doom issues!
|
|
|
|
;; There are two ways to load a theme. Both assume the theme is installed and
|
|
;; available. You can either set `doom-theme' or manually load a theme with the
|
|
;; `load-theme' function. This is the default:
|
|
(setq doom-theme 'doom-1337)
|
|
|
|
;; This determines the style of line numbers in effect. If set to `nil', line
|
|
;; numbers are disabled. For relative line numbers, set this to `relative'.
|
|
(setq display-line-numbers-type t)
|
|
|
|
;; If you use `org' and don't want your org files in the default location below,
|
|
;; change `org-directory'. It must be set before org loads!
|
|
(setq org-directory "~/org/")
|
|
|
|
;; Whenever you reconfigure a package, make sure to wrap your config in an
|
|
;; `after!' block, otherwise Doom's defaults may override your settings. E.g.
|
|
;;
|
|
;; (after! PACKAGE
|
|
;; (setq x y))
|
|
;;
|
|
;; The exceptions to this rule:
|
|
;;
|
|
;; - Setting file/directory variables (like `org-directory')
|
|
;; - Setting variables which explicitly tell you to set them before their
|
|
;; package is loaded (see 'C-h v VARIABLE' to look up their documentation).
|
|
;; - Setting doom variables (which start with 'doom-' or '+').
|
|
;;
|
|
';; Here are some additional functions/macros that will help you configure Doom.
|
|
;;
|
|
;; - `load!' for loading external *.el files relative to this one
|
|
;; - `use-package!' for configuring packages
|
|
;; - `after!' for running code after a package has loaded
|
|
;; - `add-load-path!' for adding directories to the `load-path', relative to
|
|
;; this file. Emacs searches the `load-path' when you load packages with
|
|
;; `require' or `use-package'.
|
|
;; - `map!' for binding new keys
|
|
;;
|
|
;; To get information about any of these functions/macros, move the cursor over
|
|
;; the highlighted symbol at press 'K' (non-evil users must press 'C-c c k').
|
|
;; This will open documentation for it, including demos of how they are used.
|
|
;; Alternatively, use `C-h o' to look up a symbol (functions, variables, faces,
|
|
;; etc).
|
|
;;
|
|
;; You can also try 'gd' (or 'C-c c d') to jump to their definition and see how
|
|
;; they are implemented.
|
|
|
|
(after! lsp-ui
|
|
;; sideline is super noisy
|
|
(setq lsp-ui-sideline-enable nil))
|
|
|
|
(after! org-journal
|
|
(setq org-journal-dir "~/org/journal/"))
|
|
|
|
(after! counsel
|
|
(ivy-rich-mode 1)
|
|
(all-the-icons-ivy-rich-mode 1))
|
|
|
|
(use-package! mgr-gitlab
|
|
:load-path "lisp/mgr-gitlab"
|
|
:ensure t
|
|
:config
|
|
(setq gitlab-host "https://gitlab.maxregan.me"
|
|
gitlab-token-id (if (file-exists-p mgr-gitlab-token-file)
|
|
(with-temp-buffer
|
|
(insert-file-contents mgr-gitlab-token-file)
|
|
(string-trim (buffer-string)))
|
|
nil)
|
|
dashboard-projects-backend 'projectile
|
|
dashboard-items '((mgr-gitlab-gitlab-projects . 10)
|
|
(recents . 5)
|
|
(agenda . 5)
|
|
(projects . 5))))
|
|
|
|
(use-package! persp-mode
|
|
:config
|
|
(setq persp-emacsclient-init-frame-behaviour-override "main"))
|
|
|
|
;; Hey doom, +ivy/compile is worse, give me projectile-compile-project back
|
|
(define-key (current-global-map) [remap projectile-compile-project] 'projectile-compile-project)
|
|
|
|
(use-package! denote
|
|
:config (setq denote-known-keywords '("meta" "emacs")
|
|
denote-directory "~/notes/denote"))
|
|
|
|
(use-package! uniquify
|
|
:config
|
|
(setq uniquify-buffer-name-style 'post-forward))
|
|
|
|
(use-package! clipetty
|
|
:config (global-clipetty-mode 1))
|
|
|
|
(use-package! vterm
|
|
:config
|
|
(push '("magit" magit) vterm-eval-cmds)
|
|
(push '("compile" compile) vterm-eval-cmds))
|
|
|
|
(use-package! with-editor
|
|
:config
|
|
(add-hook 'shell-mode-hook 'with-editor-export-editor)
|
|
(add-hook 'eshell-mode-hook 'with-editor-export-editor)
|
|
(add-hook 'term-exec-hook 'with-editor-export-editor)
|
|
(add-hook 'vterm-exec-hook 'with-editor-export-editor))
|
|
|
|
;; Utils for pinning buffers in windows. This is useful for compilation and shells.
|
|
|
|
(defun dedicate-window ()
|
|
(interactive)
|
|
(set-window-dedicated-p (get-buffer-window) t))
|
|
|
|
(defun undedicate-window ()
|
|
(interactive)
|
|
(set-window-dedicated-p (get-buffer-window) nil))
|
|
|
|
(defun disable-format-on-save ()
|
|
(interactive)
|
|
(format-all-mode -1))
|
|
|
|
;; Load optional site-specific config (e.g. work profiles)
|
|
(if (file-exists-p "~/.doom-site/config.el")
|
|
(load-file "~/.doom-site/config.el"))
|