diff options
Diffstat (limited to 'doom.d/modules/config.org')
-rw-r--r-- | doom.d/modules/config.org | 342 |
1 files changed, 342 insertions, 0 deletions
diff --git a/doom.d/modules/config.org b/doom.d/modules/config.org new file mode 100644 index 0000000..0428f49 --- /dev/null +++ b/doom.d/modules/config.org @@ -0,0 +1,342 @@ +#+TITLE: Oreodave's Emacs configuration +#+AUTHOR: Oreodave +#+DESCRIPTION: My Doom Emacs configuration! + +* Preclude +This is my [[https://github.com/hlissner/doom-emacs][Doom Emacs]] configuration, which I try to use for as many things as +possible. It is currently my main editor overall, literally overtaking my life. +* Variables +Bootstrapping literate module and setting up basic variables. +** Bootstrap literate +Load the literate.el file to start parsing. +#+BEGIN_SRC elisp +(load (expand-file-name (concat doom-private-dir "bin/literate.el"))) +#+END_SRC +** Doom Variables +#+BEGIN_SRC elisp +(after! core-keybinds + (setq doom-localleader-key ",") + (setq doom-theme 'doom-molokai) + (setq doom-font (font-spec :family "Hack" :size 20))) +#+END_SRC +- Set the doom localleader to "," because it's faster +- Using the font [[https://sourcefoundry.org/hack/][Hack]] with Fira code ligatures +** Other variables +#+BEGIN_SRC elisp +(setq completion-ignore-case t) +(setq truncate-lines t) +(setq display-line-numbers-type nil) +(display-battery-mode 1) +(setq-default frame-title-format '("%b - εmacs")) +(cl-pushnew '("Libgen" "https://libgen.me/search/all?search=%s") +lookup-provider-url-alist :key #'car) +#+END_SRC +Some quality of life things and others that I couldn't really put in one category +- Displaying line numbers isn't usually something I do. If need be, I'll just + open them with *<SPC>tl*. +- Set org directory +- Add libgen to search providers +- Looking at my battery percentage isn't very necessary but still really cool +* +* Internal Config +** Projectile +#+BEGIN_SRC elisp +(after! projectile + (setq oreodave-tags-alist '("Makefile" "node_modules" "bin" "dist" "obj" "'*.json'")) + (defun oreodave/config/construct-tags () + (reduce (lambda (x y) (concat x y)) (mapcar (lambda (i) (concat " --exclude=" i)) oreodave-tags-alist) + :initial-value "exctags -Re ") + ) + (setq projectile-tags-command (oreodave/config/construct-tags)) + (cl-pushnew "CMakeLists.txt" projectile-project-root-files :test #'string=) + (cl-pushnew "README.org" projectile-project-root-files :test #'string=) + (cl-pushnew "doc.org" projectile-project-root-files :test #'string=)) +#+END_SRC + +Really simple, just want to set projectile-tags-command when projectile has +loaded, and easily add new ignores if necessary. Add a new ignore to the tags-alist. + +Add a few items to the projectile-root-files list +** DAP +#+BEGIN_SRC elisp +(after! dap-mode + (defun oreodave/debug () + (interactive) + (dap-ui-mode) + (dap-ui-locals) + (dap-ui-sessions)) + (map! + :leader + :desc "Start debugging setup" "cD" #'oreodave/debug)) +#+END_SRC +A keybind and a routine + +- Routine sets up the panes that I like to use, instead of having to M-x'ing it +- *<SPC>cD* starts up the routine + +** Wakatime +#+BEGIN_SRC elisp +(use-package! wakatime-mode + :defer 1 + :config + (setq wakatime-cli-path (expand-file-name "~/.local/bin/wakatime")) + (setq wakatime-api-key (password-store-get "Keys/Wakatime")) + (global-wakatime-mode +1)) +#+END_SRC +Using new password holder (pass) to help with secure transactions. Doing all +other stuff as well, cos Henrik may remove the Wakatime module. +** Elfeed +#+BEGIN_SRC elisp +(after! elfeed + (defun oreodave/elfeed/load-feeds () + (interactive) + (setq elfeed-feeds nil) + (elfeed-load-opml (concat org-directory "/elfeed.opml"))) + + (defun oreodave/elfeed/on-new-feed () + (interactive) + (elfeed-org-export-opml) + (write-file (concat org-directory "/elfeed.opml")) + (kill-current-buffer)) + + (map! + (:map elfeed-search-mode-map + :localleader + :desc "Update feeds" "u" #'elfeed-update) + (:leader + :prefix "o" + :desc "Open RSS" "f" #'=rss)) + + (add-hook 'elfeed-org-new-entry-hook 'oreodave/elfeed/on-new-feed)) +#+END_SRC +** Dashboard +#+BEGIN_SRC elisp +(defun doom-display-benchmark-h (&optional return-p) + "Display a benchmark, showing number of packages and modules, and how quickly +they were loaded at startup. + +If RETURN-P, return the message as a string instead of displaying it." + (funcall (if return-p #'format #'message) + "εmacs loaded %d packages, %d modules in %.03fs" + (- (length load-path) (length doom--initial-load-path)) + (if doom-modules (hash-table-count doom-modules) 0) + (or doom-init-time + (setq doom-init-time + (float-time (time-subtract (current-time) before-init-time)))))) + +(setq fancy-splash-image "~/Pictures/space.png") ; splash image +(setq +doom-dashboard-name "*dashboard*") + +(setq +doom-dashboard-functions ; limit the dashboard items + '(doom-dashboard-widget-banner + doom-dashboard-widget-shortmenu + doom-dashboard-widget-loaded)) + +(setq +doom-dashboard-menu-sections ; Set a specific amount of items + '(("Open org-agenda" + :icon (all-the-icons-octicon "calendar" :face 'font-lock-keyword-face) + :when (fboundp 'org-agenda) + :action org-agenda) + ("Open books" + :icon (all-the-icons-octicon "book" :face 'font-lock-keyword-face) + :action oreodave/goto-books) + ("Check the weather" + :icon (all-the-icons-wicon "rain" :face 'font-lock-keyword-face) + :action oreodave/weather) + ("Jump to bookmark" + :icon (all-the-icons-octicon "bookmark" :face 'font-lock-keyword-face) + :action bookmark-jump))) +#+END_SRC +- Space image comes from [[https://flaticon.com][website]] +- Remove the Github link to the official Doom Emacs repository: it's in muscle memory + at this point. +- Added my own menu items: + - Books + - Weather +* Language Config +** C-style languages +#+BEGIN_SRC elisp +(after! cc-mode + (c-add-style "Allman" + '((c-basic-offset . 2) + (c-comment-only-line-offset . 0) + (c-hanging-braces-alist (brace-list-open) + (brace-entry-open) + (substatement-open after) + (block-close . c-snug-do-while) + (arglist-cont-nonempty)) + (c-cleanup-list brace-else-brace) + (c-offsets-alist + (statement-block-intro . +) + (knr-argdecl-intro . 0) + (substatement-open . 0) + (substatement-label . 0) + (label . 0) + (statement-cont . +)))) + (c-add-style "C#" + '((c-basic-offset . 4) + (c-comment-only-line-offset .0) + (c-hanging-braces-alist (brace-list-open) + (brace-entry-open) + (substatement-open after) + (block-close . c-snug-do-while) + (arglist-cont-nonempty)) + (c-cleanup-list brace-else-brace) + (c-offsets-alist + (statement-block-intro . 0) + (knr-argdecl-intro . 0) + (substatement-open . 0) + (substatement-label . 0) + (statement-cont . +) + (label . 0))))) +#+END_SRC +Emacs doesn't have the full range of styles that I want, so lemme just do it myself. +** CSharp +#+BEGIN_SRC elisp +(after! csharp-mode + (setq omnisharp-server-executable-path "~/bin/omnisharp-roslyn/run") + (defun oreodave/csharp/get-unit-test-in-project () + "Unit test anywhere using CTags or ETags and C#" + (interactive) + (let* ((tags-file (counsel-etags-locate-tags-file)) + (cands (counsel-etags-collect-cands "void.*Test" t buffer-file-name))) ; void.*Test assumes your tests are using something like XUnit and end with Test + (ivy-read + "Choose test: " + cands + :action + (lambda (item) + ;; From the counsel-etags file-open-api function + (when (string-match "\\`\\(.*?\\):\\([0-9]+\\):\\(.*\\)\\'" item) + (let* + ((file (match-string-no-properties 1 item)) + (linenum (match-string-no-properties 2 item)) + ;; always calculate path relative to TAGS + (default-directory (counsel-etags-tags-file-directory))) + + (counsel-etags-push-marker-stack (point-marker)) + (find-file file) + (counsel-etags-forward-line linenum) + (omnisharp-unit-test-at-point)))) + :caller 'oreodave/csharp/get-unit-tests-in-project))) + + (add-hook! 'csharp-mode-hook + '(lambda() + (omnisharp-mode) + (c-set-style "C#"))) ; Hook for csharp setting variables + + (map! ; CSharp Keybinds + :map csharp-mode-map + :localleader + :desc "Format buffer" "=" #'omnisharp-code-format-entire-file + (:prefix "t" + :desc "Select Test in Project" "t" #'oreodave/csharp/get-unit-test-in-project))) + #+END_SRC + +- I have custom installed the omnisharp roslyn executable, so I'd rather use + that +- C# code is better at 4 space indents, but I indent most of my C code at 2 + space indents because it looks nicer :) +- Implemented my own function which piggy backs counsel etags to globally search + tags for test specific context, then goes to it and uses an omnisharp test + command to unit test it. Basically global test search in C# projects. To use + this, just make sure you have tags compiled and that all your tests are + written as some public void *name* _Test (i.e. they are appended with _Test so + that the pattern can be matched) +** Python +#+BEGIN_SRC elisp +(after! python + (setq python-version-checked t) + (setq python-python-command "python3") + (setq python-shell-interpreter "python3") + (setq flycheck-python-pycompile-executable "python3") + + (map! ; Python keybinds + :map python-mode-map + :localleader + :desc "Start python minor" "c" #'run-python + :desc "Format buffer" "=" #'py-yapf-buffer + (:prefix "s" + :desc "Send region REPL" "r" #'python-shell-send-region + :desc "Send buffer" "b" #'python-shell-send-buffer + :desc "Send function" "f" #'python-shell-send-defun))) +#+END_SRC +- I do python development for Python3, so I need to set the flycheck python checker, as well as the interpreter, to be Python3 +- Most of my python work is in scripts or ideas, so I don't need extensive testing utilities or anything like that +- I run my python code a LOT and thus need commands for sending bits or whole scripts into the REPL +** TypeScript +#+BEGIN_SRC elisp +(after! typescript-mode + (setq typescript-indent-level 2) + (setq tide-format-options '(:indentSize 2 :tabSize 2)) + (after! lsp + (cl-pushnew '(typescript-mode . "typescript") lsp-language-id-configuration :key #'car) + (lsp-register-client + (make-lsp-client + :new-connection (lsp-stdio-connection "typescript-language-server --stdio") + :major-modes '(typescript-mode) + :server-id 'typescript)))) +#+END_SRC +- Typescript (in my opinion) should be indented by 2 +- Setup the LSP server on the lsp-language-id-config in case it hasn't already +* Keymap +#+BEGIN_SRC elisp +(map! + :leader + :desc "Compile via make" "cC" #'+make/run ; I compile stuff all the time + :desc "Shell command" "!" #'shell-command ; Better than M-! + + (:prefix ("m" . "personal") ; Personal + :desc "Open books" "b" #'oreodave/goto-books ; I like my books + :desc "Open school dir" "s" #'oreodave/goto-school ; I like my schooling + :desc "Open weather" "w" #'oreodave/weather ; Nah I don't like the weather + :desc "Change theme" "t" #'oreodave/set-new-theme ; From my own collection + :desc "Reload emacs" "r" #'oreodave/reload) ; Reload is necessary + + (:after counsel ; Counsel or ivy + :desc "M-x" "<SPC>" #'counsel-M-x ; Redefine as M-x because of my muscle memory with spacemacs + :desc "Find file here" "f." #'counsel-find-file ; Sometimes use this instead of <SPC>ff + (:prefix ("/" . "search") + :desc "FZF!" "f" #'counsel-fzf ; Just in case I need a counsel-ui for a gitignored directory + :desc "RipGrep!" "r" #'counsel-rg ; Ripgrep is faster than Ag in most cases and makes me feel cool + :desc "Search Tags" "t" #'counsel-etags-find-tag + :desc "List Tags" "T" #'counsel-etags-list-tag + :desc "Buffer Tags" "s" #'counsel-imenu + :desc "Lookup" "o" #'+lookup/online + :desc "Lookup select" "O" #'+lookup/online-select + :desc "Search buffer" "/" #'swiper-isearch)); is quicker to do than <SPC>/b, for something that is done so often + + (:prefix ("w" . "window") ; Windows + :desc "Close window" "d" #'+workspace/close-window-or-workspace ; is slightly closer together than <SPC>wc + :desc "Switch window" "W" #'ace-window ; is also used in spacemacs so I'd rather use this + :desc "Swap windows" "S" #'ace-swap-window) ; allows me to switch windows more efficiently than before, better than just motions + + (:prefix ("c" . "code") ; Code + :desc "Fold all in level" "f" #'hs-hide-level + (:after format-all + :desc "Format code" "=" #'format-all-buffer) + (:after lsp + :desc "Execute action" "a" #'lsp-execute-code-action)) + + (:prefix ("b" . "buffers") ; Buffers + :desc "Close buffer" "d" #'doom/kill-this-buffer-in-all-windows) + + (:after projectile + :desc "Switch to p-buffer" ">" #'projectile-switch-to-buffer ; Opposing <SPC>< which counsel's all buffers + (:prefix ("p" . "project") + :desc "Regen tags" "g" #'projectile-regenerate-tags + :desc "Open project files" "f" #'projectile-find-file)) + + (:prefix ("z" . "font") ; Fonts + :desc "Increase font" "+" #'doom/increase-font-size + :desc "Decrease font" "-" #'doom/decrease-font-size + :desc "Adjust font" "z" #'text-scale-adjust) + + (:prefix ("F" . "frame") ; Frames + :desc "Kill frame" "d" #'delete-frame + :desc "Current buffer frame" "m" #'make-frame + :desc "Choose Buffer frame" "n" #'display-buffer-other-frame + :desc "Switch frames" "o" #'other-frame) + + (:prefix ("o" . "open") + :after org + :desc "Calendar" "c" #'=calendar)) +#+END_SRC |