From d656f499c6241bdbfa1a098d1a2c1732f22994d2 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Sun, 14 Apr 2024 14:35:39 +0630 Subject: (Emacs/core)+evil-numbers packages Increment/decrement number at point. Something from vim which is quite nice. --- Emacs/.config/emacs/core.org | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 9ff0905..26be8ab 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -271,6 +271,17 @@ though, as I may disagree with some. So I use it in a mode to mode basis. (use-package evil-collection :after evil) #+end_src +** Evil number +Increment/decrement a number at point like Vim does, but use bindings +that don't conflict with Emacs default. +#+begin_src emacs-lisp +(use-package evil-numbers + :after evil + :general + (nmmap + "+" #'evil-numbers/inc-at-pt + "-" #'evil-numbers/dec-at-pt)) +#+end_src * Completion Emacs is a text based interface. Completion is its bread and butter in providing good user experience. By default Emacs provides -- cgit v1.2.3-13-gbd6f From 40dab72e6cd8c2b4ba99bccdd9e40bd22cb9eef5 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Thu, 18 Apr 2024 14:49:22 +0630 Subject: (Emacs|^)~Some general cleanup --- Emacs/.config/emacs/core.org | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 26be8ab..53cff6d 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -116,8 +116,7 @@ Some bindings that I couldn't fit elsewhere easily. (use-package emacs :straight nil :general - (general-def - "C-x d" #'delete-frame) + ("C-x d" #'delete-frame) (nmmap "C--" #'text-scale-decrease -- cgit v1.2.3-13-gbd6f From f60c3b5bad999d961141ce73a3b71910e102fff5 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Thu, 18 Apr 2024 14:53:30 +0630 Subject: (Emacs/core)+package hydra and use-package-hydra Defines persistent sub-key-maps which can provide some really nice behavior. --- Emacs/.config/emacs/core.org | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 53cff6d..a9113f0 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -747,3 +747,16 @@ for all snippets I've got. :config (yas-load-directory (no-littering-expand-etc-file-name "yasnippet/snippets"))) #+end_src +* Hydra +Hydra is a great package by =abo-abo= (yes the same guy who made ivy +and swiper) and I hope to use it later on in the config. There are +two use-package declarations here: one for ~hydra~ itself, and the +other for ~use-package-hydra~ which provides the keyword ~:hydra~ in +use-package declarations. +#+begin_src emacs-lisp +(use-package hydra + :straight t) + +(use-package use-package-hydra + :straight t) +#+end_src -- cgit v1.2.3-13-gbd6f From 2b0397b3bcfd915fde2d2823ec1cffcebde19917 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Thu, 18 Apr 2024 15:21:27 +0630 Subject: (Emacs/*)~WIP -> WAIT for subtrees that aren't used --- Emacs/.config/emacs/core.org | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index a9113f0..0f0d9c6 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -373,7 +373,7 @@ Setup for counsel. Load after ivy and helpful. (t . ivy--regex-ignore-order))) (counsel-mode)) #+end_src -*** WIP Ivy posframe +*** WAIT Ivy posframe :PROPERTIES: :header-args:emacs-lisp: :tangle no :END: @@ -392,7 +392,7 @@ Very nice eyecandy, but can get kinda annoying. (setq ivy-posframe-display-functions-alist '((t . ivy-posframe-display-at-window-center)))) #+end_src -*** WIP Counsel etags +*** WAIT Counsel etags :PROPERTIES: :header-args:emacs-lisp: :tangle no :END: @@ -409,7 +409,7 @@ This has been replaced by [[*xref][xref]] which is inbuilt. (search-leader "t" #'counsel-etags-find-tag)) #+end_src -** WIP Ido +** WAIT Ido :PROPERTIES: :header-args:emacs-lisp: :tangle no :END: @@ -680,7 +680,7 @@ with abstracting a few things away. ("smon" (format-time-string "%B" (current-time))))) #+end_src -** WIP Skeletons +** WAIT Skeletons :PROPERTIES: :header-args:emacs-lisp: :tangle no :END: -- cgit v1.2.3-13-gbd6f From c76475e427c788ae24e12e283cb07607f89c6526 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Fri, 19 Apr 2024 04:39:42 +0530 Subject: (Emacs/*)~cleaning up --- Emacs/.config/emacs/core.org | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 0f0d9c6..bc3a2cd 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -125,7 +125,7 @@ Some bindings that I couldn't fit elsewhere easily. (leader "SPC" '(execute-extended-command :which-key "M-x") - "'" '(browse-url-emacs :which-key "Open url in Emacs") + "'" '(browse-url-emacs :which-key "Download URL to Emacs") ";" 'eval-expression ":" `(,(proc (interactive) (switch-to-buffer "*scratch*")) :which-key "Switch to *scratch*") @@ -185,7 +185,7 @@ Setup the evil package, with some opinionated keybindings: "TAB" #'evil-jump-item "r" #'evil-replace-state "zC" #'hs-hide-level - "zO" #'hs-show-all + "zO" #'hs-show-all "'" #'evil-goto-mark "`" #'evil-goto-mark-line "C-w" #'evil-window-map -- cgit v1.2.3-13-gbd6f From 5aec6298cfc2ca9889f9fababf5d38281ce0a192 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 23 Apr 2024 01:40:07 +0530 Subject: (Emacs/config|core)+move-line-{up|down} --- Emacs/.config/emacs/core.org | 5 +++++ 1 file changed, 5 insertions(+) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index bc3a2cd..b0d7e2f 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -118,6 +118,11 @@ Some bindings that I couldn't fit elsewhere easily. :general ("C-x d" #'delete-frame) + (nmmap + :keymaps 'override + "C-M-j" #'move-line-down + "C-M-k" #'move-line-up) + (nmmap "C--" #'text-scale-decrease "C-=" #'text-scale-increase -- cgit v1.2.3-13-gbd6f From a35eeb19b96a2de797df192664c5480d3c5507c7 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 23 Apr 2024 01:40:27 +0530 Subject: (Emacs/config|core)~: go to config.org -> search org heading --- Emacs/.config/emacs/core.org | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index b0d7e2f..ef0270b 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -147,10 +147,7 @@ Some bindings that I couldn't fit elsewhere easily. (file-leader "f" #'find-file "F" #'find-file-other-frame - "s" #'save-buffer - "p" `(,(proc (interactive) - (find-file (concat user-emacs-directory "config.org"))) - :which-key "Open config.org")) + "s" #'save-buffer) (quit-leader "q" #'save-buffers-kill-terminal -- cgit v1.2.3-13-gbd6f From 50a3add8751ce1b32045c18edd528460815e33e0 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 23 Apr 2024 01:41:19 +0530 Subject: (Emacs/core)+some more bindings --- Emacs/.config/emacs/core.org | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index ef0270b..8ad8c4d 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -181,6 +181,7 @@ Setup the evil package, with some opinionated keybindings: :general (leader "w" '(evil-window-map :which-key "Window") + "wT" #'window-swap-states ; transpose two windows "wd" #'delete-frame) (nmmap @@ -512,9 +513,7 @@ just setup some evil binds for company. (eshell-mode-hook . company-mode) :general (imap - "C-SPC" #'company-complete) - (general-def - :states '(normal insert) + "C-SPC" #'company-complete "M-j" #'company-select-next "M-k" #'company-select-previous)) #+end_src -- cgit v1.2.3-13-gbd6f From 1039114d2f7e1aa11a72822e212f5a27236ece53 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 23 Apr 2024 17:00:48 +0530 Subject: (Emacs/core)+nmmap binding K to man By default evil-lookup-func is woman, which throws annoying warnings and isn't a complete manpage reader. So here I rebind it to use man, which is fully functioning. --- Emacs/.config/emacs/core.org | 1 + 1 file changed, 1 insertion(+) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 8ad8c4d..759ee24 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -185,6 +185,7 @@ Setup the evil package, with some opinionated keybindings: "wd" #'delete-frame) (nmmap + "K" #'man "TAB" #'evil-jump-item "r" #'evil-replace-state "zC" #'hs-hide-level -- cgit v1.2.3-13-gbd6f From a01cba5589368b6b2c3946d1286e8b295ab3403d Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 23 Apr 2024 18:18:05 +0530 Subject: (Emacs/*)~stop using create-toggle-function --- Emacs/.config/emacs/core.org | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 759ee24..60fb64c 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -578,9 +578,13 @@ a whim and not particularly caring for the current window setup. Thankfully you can change this via the ~display-buffer-alist~ which matches buffer names with how the window for the buffer should be displayed. I add a use-package keyword to make ~display-buffer-alist~ -records within use-package. +records within a use-package call. I have no idea whether it's optimal AT ALL, but it works for me. + +2024-04-23: Found this option ~switch-to-buffer-obey-display-actions~ +which makes manual buffer switches obey the same constraints via +~display-buffer-alist~ as creating the buffer automatically. #+begin_src emacs-lisp (use-package window :straight nil @@ -593,6 +597,7 @@ I have no idea whether it's optimal AT ALL, but it works for me. "k" #'previous-buffer "D" '(+oreo/clean-buffer-list :which-key "Kill most buffers")) :init + (setq switch-to-buffer-obey-display-actions t) (with-eval-after-load "use-package-core" (add-to-list 'use-package-keywords ':display) (defun use-package-normalize/:display (_name-symbol _keyword args) -- cgit v1.2.3-13-gbd6f From 90c0766992ee1e5326d288f164569c33ceb7bda2 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Wed, 24 Apr 2024 04:02:38 +0530 Subject: (Emacs/core|config)~do a bit of clean up --- Emacs/.config/emacs/core.org | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 60fb64c..143af67 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -754,7 +754,10 @@ for all snippets I've got. :config (yas-load-directory (no-littering-expand-etc-file-name "yasnippet/snippets"))) #+end_src -* Hydra +** WAIT Hydra +:PROPERTIES: +:header-args:emacs-lisp: :tangle no +:END: Hydra is a great package by =abo-abo= (yes the same guy who made ivy and swiper) and I hope to use it later on in the config. There are two use-package declarations here: one for ~hydra~ itself, and the -- cgit v1.2.3-13-gbd6f From 8ea2b51e5afbf413b3c46f2c532b052b1028bec6 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Wed, 24 Apr 2024 04:05:31 +0530 Subject: (Emacs/core)+binding fp to use counsel-git in defiles folder Lookup all files in the repository. Best solution I could come up with. --- Emacs/.config/emacs/core.org | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 143af67..5298760 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -360,7 +360,11 @@ Setup for counsel. Load after ivy and helpful. "s" #'counsel-grep-or-swiper "r" #'counsel-rg) (file-leader - "r" #'counsel-recentf) + "r" #'counsel-recentf + "p" (proc (interactive) + (with-current-buffer (find-file-noselect + (concat user-emacs-directory "config.org")) + (counsel-git)))) (insert-leader "c" #'counsel-unicode-char) (general-def -- cgit v1.2.3-13-gbd6f From 870ce03d0279bc1ce7215c311b061d68c95fdbc1 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Sat, 27 Apr 2024 14:42:15 +0530 Subject: (Emacs/config|core|elisp)+move.el Library to move words forward and backward as well as lines up and down. These movements keep the object in question under the cursor which provides a nice experience. --- Emacs/.config/emacs/core.org | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 5298760..4756e46 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -119,9 +119,11 @@ Some bindings that I couldn't fit elsewhere easily. ("C-x d" #'delete-frame) (nmmap - :keymaps 'override - "C-M-j" #'move-line-down - "C-M-k" #'move-line-up) + :keymaps '(text-mode-map prog-mode-map) + "C-M-h" #'+move/word-backward + "C-M-j" #'+move/line-down + "C-M-k" #'+move/line-up + "C-M-l" #'+move/word-forward) (nmmap "C--" #'text-scale-decrease -- cgit v1.2.3-13-gbd6f From e7c5cd8d159e8936d9b53c53fc2eedf033c57c2c Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Sat, 27 Apr 2024 15:09:57 +0530 Subject: (Emacs/config|core)Switched fP and fp --- Emacs/.config/emacs/core.org | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 4756e46..417d978 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -363,7 +363,7 @@ Setup for counsel. Load after ivy and helpful. "r" #'counsel-rg) (file-leader "r" #'counsel-recentf - "p" (proc (interactive) + "P" (proc (interactive) (with-current-buffer (find-file-noselect (concat user-emacs-directory "config.org")) (counsel-git)))) -- cgit v1.2.3-13-gbd6f From 2986c04c2fcad44eb80ce01336ade33a7429cf7a Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 6 May 2024 02:23:38 +0530 Subject: (Emacs|Shell|SystemD)~Small changes --- Emacs/.config/emacs/core.org | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 417d978..b727f78 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -110,7 +110,7 @@ code. (general-evil-setup t)) #+end_src -** Some binds in Emacs +** Some binds for Emacs Some bindings that I couldn't fit elsewhere easily. #+begin_src emacs-lisp (use-package emacs @@ -126,6 +126,8 @@ Some bindings that I couldn't fit elsewhere easily. "C-M-l" #'+move/word-forward) (nmmap + "M-;" #'eval-expression + "g=" #'align-regexp "C--" #'text-scale-decrease "C-=" #'text-scale-increase "C-+" #'text-scale-adjust) @@ -140,7 +142,7 @@ Some bindings that I couldn't fit elsewhere easily. "h" '(help-command :which-key "Help")) (mode-leader - "t" #'+oreo/switch-theme) + "T" #'+oreo/switch-theme) (code-leader "F" `(,(proc (interactive) (find-file "~/Code/")) -- cgit v1.2.3-13-gbd6f From 1a7a3670c1e3c43c91722b68d25768e545158e88 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 6 May 2024 02:24:33 +0530 Subject: (Emacs/core)~Use standard windowing system now I've reached a level of complexity where I'd rather use Emacs to manage windows than my window manager. --- Emacs/.config/emacs/core.org | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index b727f78..9558eb9 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -33,6 +33,7 @@ code. :states '(normal motion) "SPC" 'nil "\\" '(nil :which-key "Local leader") + "SPC ;" '(nil :which-key "Shell") "SPC a" '(nil :which-key "Applications") "SPC b" '(nil :which-key "Buffers") "SPC c" '(nil :which-key "Code") @@ -40,9 +41,9 @@ code. "SPC f" '(nil :which-key "Files") "SPC i" '(nil :which-key "Insert") "SPC m" '(nil :which-key "Modes") - "SPC q" '(nil :which-key "Quit/Literate") "SPC s" '(nil :which-key "Search") "SPC t" '(nil :which-key "Shell")) + "SPC q" '(nil :which-key "Quit/Literate")) (general-create-definer leader :states '(normal motion) @@ -135,7 +136,6 @@ Some bindings that I couldn't fit elsewhere easily. (leader "SPC" '(execute-extended-command :which-key "M-x") "'" '(browse-url-emacs :which-key "Download URL to Emacs") - ";" 'eval-expression ":" `(,(proc (interactive) (switch-to-buffer "*scratch*")) :which-key "Switch to *scratch*") "!" '(async-shell-command :which-key "Async shell command") @@ -156,8 +156,8 @@ Some bindings that I couldn't fit elsewhere easily. (quit-leader "q" #'save-buffers-kill-terminal "c" #'+literate/compile-config - "l" #'+literate/load-config - "d" #'delete-frame) + "C" #'+literate/clean-config + "l" #'+literate/load-config) (search-leader "i" #'imenu)) #+end_src @@ -185,8 +185,8 @@ Setup the evil package, with some opinionated keybindings: :general (leader "w" '(evil-window-map :which-key "Window") - "wT" #'window-swap-states ; transpose two windows - "wd" #'delete-frame) + "wT" #'window-swap-states + "wd" #'evil-window-delete) (nmmap "K" #'man @@ -214,9 +214,7 @@ Setup the evil package, with some opinionated keybindings: evil-split-window-below t evil-vsplit-window-right t evil-want-abbrev-expand-on-insert-exit t - evil-undo-system #'undo-tree) - :config - (fset #'evil-window-vsplit #'make-frame)) + evil-undo-system #'undo-tree)) #+end_src ** Evil surround Evil surround is a port for vim-surround. -- cgit v1.2.3-13-gbd6f From 8c13aa67b61ba5cf1b88c304ed1c4e3e29e03d0d Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 6 May 2024 02:26:58 +0530 Subject: (Emacs/core)+Use Emacs Tabs Emacs tabs are actually quite powerful and solve the namespace problem, at least for me. This is why I started using standard windowing rather than using new frames: I can have all my workspaces in one frame. --- Emacs/.config/emacs/core.org | 36 +++++++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 9558eb9..3c2d293 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -42,7 +42,7 @@ code. "SPC i" '(nil :which-key "Insert") "SPC m" '(nil :which-key "Modes") "SPC s" '(nil :which-key "Search") - "SPC t" '(nil :which-key "Shell")) + "SPC t" '(nil :which-key "Tabs") "SPC q" '(nil :which-key "Quit/Literate")) (general-create-definer leader @@ -65,6 +65,11 @@ code. :prefix "SPC f") (general-create-definer shell-leader + :states '(normal motion) + :keymaps 'override + :prefix "SPC ;") + + (general-create-definer tab-leader :states '(normal motion) :keymaps 'override :prefix "SPC t") @@ -645,6 +650,35 @@ records. This is mostly for packages that aren't really configured (display-buffer-at-bottom) (window-height . 0.25))) #+end_src +* Tabs +Tabs in vscode are just like buffers in Emacs but way slower and +harder to use. Tabs in Emacs are essentially window layouts, similar +to instances in Tmux. With this setup I can use tabs quite +effectively. + +#+begin_src emacs-lisp +(use-package tab-bar + :straight nil + :init + (setq tab-bar-show 1) + :config + (tab-bar-mode) + :general + (tab-leader + "t" #'tab-switch + "j" #'tab-next + "k" #'tab-previous + "h" #'tab-move-to + "l" #'tab-move + "n" #'tab-new + "c" #'tab-close + "d" #'tab-close + "f" #'tab-detach + "w" #'tab-window-detach + "r" #'tab-rename) + (mode-leader + "t" #'toggle-tab-bar-mode-from-frame)) +#+end_src * Auto typing Snippets are a pretty nice way of automatically inserting code. Emacs provides a ton of packages by default to do this, but there are great -- cgit v1.2.3-13-gbd6f From 915971d5aa5a812de1ef137088c33eb92c2cc5ca Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 6 May 2024 02:34:13 +0530 Subject: (Emacs/core|config)~use drag stuff instead of move.el Works with regions! --- Emacs/.config/emacs/core.org | 7 ------- 1 file changed, 7 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 3c2d293..f4e45d4 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -124,13 +124,6 @@ Some bindings that I couldn't fit elsewhere easily. :general ("C-x d" #'delete-frame) - (nmmap - :keymaps '(text-mode-map prog-mode-map) - "C-M-h" #'+move/word-backward - "C-M-j" #'+move/line-down - "C-M-k" #'+move/line-up - "C-M-l" #'+move/word-forward) - (nmmap "M-;" #'eval-expression "g=" #'align-regexp -- cgit v1.2.3-13-gbd6f From 9aa6de5f2433b457f2aa7b89bf6301074e1d7f21 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 6 May 2024 23:50:06 +0530 Subject: (Emacs/config|core)~projectile -> project Removing a dependency! --- Emacs/.config/emacs/core.org | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index f4e45d4..9326f02 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -133,11 +133,12 @@ Some bindings that I couldn't fit elsewhere easily. (leader "SPC" '(execute-extended-command :which-key "M-x") + "p" `(,project-prefix-map :which-key "Project") "'" '(browse-url-emacs :which-key "Download URL to Emacs") ":" `(,(proc (interactive) (switch-to-buffer "*scratch*")) :which-key "Switch to *scratch*") "!" '(async-shell-command :which-key "Async shell command") - "h" '(help-command :which-key "Help")) + "h" '(help-command :which-key "Help")) (mode-leader "T" #'+oreo/switch-theme) -- cgit v1.2.3-13-gbd6f From 6656253cacf198380fd764c99895b7dd5c7d68ed Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 7 May 2024 01:32:21 +0530 Subject: (Emacs/config|core)~switch ripgrep bindings --- Emacs/.config/emacs/core.org | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 9326f02..2e80e8a 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -359,7 +359,7 @@ Setup for counsel. Load after ivy and helpful. :general (search-leader "s" #'counsel-grep-or-swiper - "r" #'counsel-rg) + "R" #'counsel-rg) (file-leader "r" #'counsel-recentf "P" (proc (interactive) -- cgit v1.2.3-13-gbd6f From 4f2ec316e45810e428a1d8f8750fff52a9e7d992 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Tue, 7 May 2024 23:56:57 +0530 Subject: (Emacs/config|core)+some defers --- Emacs/.config/emacs/core.org | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 2e80e8a..b0bc70d 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -179,7 +179,7 @@ Setup the evil package, with some opinionated keybindings: - Use 'T' character as an action for transposing objects #+begin_src emacs-lisp (use-package evil - :demand t + :defer t :hook (after-init-hook . evil-mode) :general (leader @@ -652,6 +652,7 @@ effectively. #+begin_src emacs-lisp (use-package tab-bar + :defer t :straight nil :init (setq tab-bar-show 1) -- cgit v1.2.3-13-gbd6f From 7105788014b2ab8a31c8dbc69dc489f5762babbc Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Fri, 10 May 2024 01:05:16 +0530 Subject: (Emacs/core)~Switched prefixes for tab and shell leader --- Emacs/.config/emacs/core.org | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index b0bc70d..3902e51 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -33,7 +33,7 @@ code. :states '(normal motion) "SPC" 'nil "\\" '(nil :which-key "Local leader") - "SPC ;" '(nil :which-key "Shell") + "SPC ;" '(nil :which-key "Tabs") "SPC a" '(nil :which-key "Applications") "SPC b" '(nil :which-key "Buffers") "SPC c" '(nil :which-key "Code") @@ -42,7 +42,7 @@ code. "SPC i" '(nil :which-key "Insert") "SPC m" '(nil :which-key "Modes") "SPC s" '(nil :which-key "Search") - "SPC t" '(nil :which-key "Tabs") + "SPC t" '(nil :which-key "Shell") "SPC q" '(nil :which-key "Quit/Literate")) (general-create-definer leader -- cgit v1.2.3-13-gbd6f From 6aa3c170e93ea9a88b16816a3396778def524a01 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Sat, 11 May 2024 13:05:41 +0530 Subject: (Emacs/*)~clean up text, change license of elisp packages to GPLv2 strictly --- Emacs/.config/emacs/core.org | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 3902e51..5472ea4 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -7,8 +7,8 @@ #+startup: noindent Packages that are absolutely necessary for the rest of the -configuration. These yield core functionality such as keybinding, -modal editing, completion, auto typing to name a few. +configuration. Window management, Keybindings or completion +frameworks; they're all done here. * General General provides a great solution for binding keys. It has evil and use-package support so it fits nicely into configuration. In this -- cgit v1.2.3-13-gbd6f From 5567f2647d01b78108085aa8eb5ffefc9dd7c119 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Sat, 11 May 2024 13:06:29 +0530 Subject: (Emacs/core)~tabs now use r as a prefix key --- Emacs/.config/emacs/core.org | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 5472ea4..1fc4f98 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -33,7 +33,6 @@ code. :states '(normal motion) "SPC" 'nil "\\" '(nil :which-key "Local leader") - "SPC ;" '(nil :which-key "Tabs") "SPC a" '(nil :which-key "Applications") "SPC b" '(nil :which-key "Buffers") "SPC c" '(nil :which-key "Code") @@ -41,6 +40,7 @@ code. "SPC f" '(nil :which-key "Files") "SPC i" '(nil :which-key "Insert") "SPC m" '(nil :which-key "Modes") + "SPC r" '(nil :which-key "Tabs") "SPC s" '(nil :which-key "Search") "SPC t" '(nil :which-key "Shell") "SPC q" '(nil :which-key "Quit/Literate")) @@ -67,12 +67,12 @@ code. (general-create-definer shell-leader :states '(normal motion) :keymaps 'override - :prefix "SPC ;") + :prefix "SPC t") (general-create-definer tab-leader :states '(normal motion) :keymaps 'override - :prefix "SPC t") + :prefix "SPC r") (general-create-definer mode-leader :states '(normal motion) -- cgit v1.2.3-13-gbd6f From eacfab80dd04777650b4ea665c0fb4b3bfae73de Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Sat, 11 May 2024 13:45:20 +0530 Subject: (Emacs/config)+Custom function to generate tags from project root --- Emacs/.config/emacs/core.org | 1 + 1 file changed, 1 insertion(+) (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org index 1fc4f98..cb9d19f 100644 --- a/Emacs/.config/emacs/core.org +++ b/Emacs/.config/emacs/core.org @@ -783,6 +783,7 @@ for all snippets I've got. :defer t :hook (prog-mode-hook . yas-minor-mode) + (text-mode-hook . yas-minor-mode) :general (insert-leader "i" #'yas-insert-snippet) -- cgit v1.2.3-13-gbd6f From 8fcdfac6614e1ea84f2bfd100b5713ce7dce2db0 Mon Sep 17 00:00:00 2001 From: Aryadev Chavali Date: Mon, 13 May 2024 16:58:28 +0530 Subject: (Emacs)~Merged app.org, lang.org and core.org back into config.org Just makes it easier to profile and deal with compilation --- Emacs/.config/emacs/core.org | 808 ------------------------------------------- 1 file changed, 808 deletions(-) delete mode 100644 Emacs/.config/emacs/core.org (limited to 'Emacs/.config/emacs/core.org') diff --git a/Emacs/.config/emacs/core.org b/Emacs/.config/emacs/core.org deleted file mode 100644 index cb9d19f..0000000 --- a/Emacs/.config/emacs/core.org +++ /dev/null @@ -1,808 +0,0 @@ -#+title: Core packages -#+author: Aryadev Chavali -#+description: The core components of my configuration -#+date: 2023-09-29 -#+property: header-args:emacs-lisp :tangle core.el :comments link :results none -#+options: toc:nil -#+startup: noindent - -Packages that are absolutely necessary for the rest of the -configuration. Window management, Keybindings or completion -frameworks; they're all done here. -* General -General provides a great solution for binding keys. It has evil and -use-package support so it fits nicely into configuration. In this -case, I define a "definer" for the "LEADER" keys. Leader is bound to -~SPC~ and it's functionally equivalent to the doom/spacemacs leader. -Local leader is bound to ~SPC ,~ and it's similar to doom/spacemacs -leader but doesn't try to fully assimilate the local-leader map, -instead just picking stuff I think is useful. This forces me to learn -only as many bindings as I find necessary; no more, no less. - -I also define prefix leaders for differing applications. These are -quite self explanatory by their name and provide a nice way to -visualise all bindings under a specific heading just by searching the -code. -#+begin_src emacs-lisp -(use-package general - :straight t - :demand t - :config - ;; General which key definitions for leaders - (general-def - :states '(normal motion) - "SPC" 'nil - "\\" '(nil :which-key "Local leader") - "SPC a" '(nil :which-key "Applications") - "SPC b" '(nil :which-key "Buffers") - "SPC c" '(nil :which-key "Code") - "SPC d" '(nil :which-key "Directories") - "SPC f" '(nil :which-key "Files") - "SPC i" '(nil :which-key "Insert") - "SPC m" '(nil :which-key "Modes") - "SPC r" '(nil :which-key "Tabs") - "SPC s" '(nil :which-key "Search") - "SPC t" '(nil :which-key "Shell") - "SPC q" '(nil :which-key "Quit/Literate")) - - (general-create-definer leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC") - - (general-create-definer local-leader - :states '(normal motion) - :prefix "\\") - - (general-create-definer code-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC c") - - (general-create-definer file-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC f") - - (general-create-definer shell-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC t") - - (general-create-definer tab-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC r") - - (general-create-definer mode-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC m") - - (general-create-definer app-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC a") - - (general-create-definer search-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC s") - - (general-create-definer buffer-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC b") - - (general-create-definer quit-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC q") - - (general-create-definer insert-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC i") - - (general-create-definer dir-leader - :states '(normal motion) - :keymaps 'override - :prefix "SPC d") - - (general-create-definer general-nmmap - :states '(normal motion)) - - (defalias 'nmmap #'general-nmmap) - - (general-evil-setup t)) -#+end_src -** Some binds for Emacs -Some bindings that I couldn't fit elsewhere easily. -#+begin_src emacs-lisp -(use-package emacs - :straight nil - :general - ("C-x d" #'delete-frame) - - (nmmap - "M-;" #'eval-expression - "g=" #'align-regexp - "C--" #'text-scale-decrease - "C-=" #'text-scale-increase - "C-+" #'text-scale-adjust) - - (leader - "SPC" '(execute-extended-command :which-key "M-x") - "p" `(,project-prefix-map :which-key "Project") - "'" '(browse-url-emacs :which-key "Download URL to Emacs") - ":" `(,(proc (interactive) (switch-to-buffer "*scratch*")) - :which-key "Switch to *scratch*") - "!" '(async-shell-command :which-key "Async shell command") - "h" '(help-command :which-key "Help")) - - (mode-leader - "T" #'+oreo/switch-theme) - - (code-leader - "F" `(,(proc (interactive) (find-file "~/Code/")) - :which-key "Open ~/Code/")) - - (file-leader - "f" #'find-file - "F" #'find-file-other-frame - "s" #'save-buffer) - - (quit-leader - "q" #'save-buffers-kill-terminal - "c" #'+literate/compile-config - "C" #'+literate/clean-config - "l" #'+literate/load-config) - - (search-leader "i" #'imenu)) -#+end_src -* Evil -My editor journey started off with Vim rather than Emacs, so my brain -has imprinted on its style. Thankfully Emacs is super extensible so -there exists a package (more of a supreme system) for porting Vim's -modal editing style to Emacs, called Evil (Emacs Vi Layer). - -However there are a lot of packages in Vim that provide greater -functionality, for example 'vim-surround'. Emacs, by default, has -these capabilities but there are further packages which integrate them -into Evil. -** Evil core -Setup the evil package, with some opinionated keybindings: -- Switch ~evil-upcase~ and ~evil-downcase~ because I use ~evil-upcase~ - more -- Switch ~evil-goto-mark~ and ~evil-goto-mark-line~ as I'd rather have - the global one closer to the home row -- Use 'T' character as an action for transposing objects -#+begin_src emacs-lisp -(use-package evil - :defer t - :hook (after-init-hook . evil-mode) - :general - (leader - "w" '(evil-window-map :which-key "Window") - "wT" #'window-swap-states - "wd" #'evil-window-delete) - - (nmmap - "K" #'man - "TAB" #'evil-jump-item - "r" #'evil-replace-state - "zC" #'hs-hide-level - "zO" #'hs-show-all - "'" #'evil-goto-mark - "`" #'evil-goto-mark-line - "C-w" #'evil-window-map - "gu" #'evil-upcase - "gU" #'evil-downcase - "T" nil) - - (nmmap - :infix "T" - "w" #'transpose-words - "c" #'transpose-chars - "s" #'transpose-sentences - "p" #'transpose-paragraphs - "e" #'transpose-sexps - "l" #'transpose-lines) - :init - (setq evil-want-keybinding nil - evil-split-window-below t - evil-vsplit-window-right t - evil-want-abbrev-expand-on-insert-exit t - evil-undo-system #'undo-tree)) -#+end_src -** Evil surround -Evil surround is a port for vim-surround. -#+begin_src emacs-lisp -(use-package evil-surround - :after evil - :config - (global-evil-surround-mode)) -#+end_src -** Evil commentary -Allows generalised commenting of objects easily. -#+begin_src emacs-lisp -(use-package evil-commentary - :after evil - :config - (evil-commentary-mode)) -#+end_src -** Evil multi cursor -Setup for multi cursors in Evil mode. Don't let evil-mc setup it's own -keymap because it uses 'gr' as its prefix, which I don't like. -#+begin_src emacs-lisp -(use-package evil-mc - :after evil - :init - (defvar evil-mc-key-map (make-sparse-keymap)) - :general - (nmap - :infix "gz" - "q" #'evil-mc-undo-all-cursors - "d" #'evil-mc-make-and-goto-next-match - "j" #'evil-mc-make-cursor-move-next-line - "k" #'evil-mc-make-cursor-move-prev-line - "j" #'evil-mc-make-cursor-move-next-line - "m" #'evil-mc-make-all-cursors - "z" #'evil-mc-make-cursor-here - "r" #'evil-mc-resume-cursors - "s" #'evil-mc-pause-cursors - "u" #'evil-mc-undo-last-added-cursor) - :config - ;; (evil-mc-define-vars) - ;; (evil-mc-initialize-vars) - ;; (add-hook 'evil-mc-before-cursors-created #'evil-mc-pause-incompatible-modes) - ;; (add-hook 'evil-mc-before-cursors-created #'evil-mc-initialize-active-state) - ;; (add-hook 'evil-mc-after-cursors-deleted #'evil-mc-teardown-active-state) - ;; (add-hook 'evil-mc-after-cursors-deleted #'evil-mc-resume-incompatible-modes) - ;; (advice-add #'evil-mc-initialize-hooks :override #'ignore) - ;; (advice-add #'evil-mc-teardown-hooks :override #'evil-mc-initialize-vars) - ;; (advice-add #'evil-mc-initialize-active-state :before #'turn-on-evil-mc-mode) - ;; (advice-add #'evil-mc-teardown-active-state :after #'turn-off-evil-mc-mode) - ;; (add-hook 'evil-insert-state-entry-hook #'evil-mc-resume-cursors) - (global-evil-mc-mode)) -#+end_src - -** Evil collection -Provides a community based set of keybindings for most modes in -Emacs. I don't necessarily like all my modes having these bindings -though, as I may disagree with some. So I use it in a mode to mode basis. -#+begin_src emacs-lisp -(use-package evil-collection - :after evil) -#+end_src -** Evil number -Increment/decrement a number at point like Vim does, but use bindings -that don't conflict with Emacs default. -#+begin_src emacs-lisp -(use-package evil-numbers - :after evil - :general - (nmmap - "+" #'evil-numbers/inc-at-pt - "-" #'evil-numbers/dec-at-pt)) -#+end_src -* Completion -Emacs is a text based interface. Completion is its bread and butter -in providing good user experience. By default Emacs provides -'completions-list' which produces a buffer of options which can be -searched and selected. We can take this further though! - -Ido and Icomplete are packages distributed with Emacs to provide -greater completion interfaces. They utilise the minibuffer to create -a more interactive experience, allowing incremental searches and -option selection. - -Ivy and Helm provide more modern interfaces, though Helm is quite -heavy. Ivy, on the other hand, provides an interface similar to Ido -with less clutter and better customisation options. -** Ivy -Ivy is a completion framework for Emacs, and my preferred one. It has -a great set of features with little to no pain with setting up. -*** Ivy Core -Setup for ivy, in preparation for counsel. Turn on ivy-mode just -after init. - -Setup vim-like bindings for the minibuffer ("M-(j|k)" for down|up the -selection list). -#+begin_src emacs-lisp -(use-package ivy - :defer t - :hook (after-init-hook . ivy-mode) - :general - (general-def - :keymaps 'ivy-minibuffer-map - "C-j" #'ivy-yank-symbol - "M-j" #'ivy-next-line-or-history - "M-k" #'ivy-previous-line-or-history - "C-SPC" #'ivy-occur) - (general-def - :keymaps 'ivy-switch-buffer-map - "M-j" #'ivy-next-line-or-history - "M-k" #'ivy-previous-line-or-history) - (nmap - :keymaps '(ivy-occur-mode-map ivy-occur-grep-mode-map) - "RET" #'ivy-occur-press-and-switch - "J" #'ivy-occur-press - "gr" #'ivy-occur-revert-buffer - "q" #'quit-window - "D" #'ivy-occur-delete-candidate - "W" #'ivy-wgrep-change-to-wgrep-mode - "{" #'compilation-previous-file - "}" #'compilation-next-file) - :init - (with-eval-after-load "evil" - (evil-set-initial-state 'ivy-occur-mode 'normal) - (evil-set-initial-state 'ivy-occur-grep-mode 'normal)) - (with-eval-after-load "amx" - (setq amx-backend 'ivy)) - - (setq ivy-height 10 - ivy-wrap t - ivy-fixed-height-minibuffer t - ivy-use-virtual-buffers nil - ivy-virtual-abbreviate 'full - ivy-on-del-error-function #'ignore - ivy-use-selectable-prompt t) - :config - (require 'counsel nil t)) -#+end_src -*** Counsel -Setup for counsel. Load after ivy and helpful. -#+begin_src emacs-lisp -(use-package counsel - :defer t - :general - (search-leader - "s" #'counsel-grep-or-swiper - "R" #'counsel-rg) - (file-leader - "r" #'counsel-recentf - "P" (proc (interactive) - (with-current-buffer (find-file-noselect - (concat user-emacs-directory "config.org")) - (counsel-git)))) - (insert-leader - "c" #'counsel-unicode-char) - (general-def - [remap describe-bindings] #'counsel-descbinds - [remap load-theme] #'counsel-load-theme) - :config - (setq ivy-initial-inputs-alist '((org-insert-link . "^")) - counsel-describe-function-function #'helpful-callable - counsel-describe-variable-function #'helpful-variable - counsel-grep-swiper-limit 1500000 - ivy-re-builders-alist '((swiper . ivy--regex-plus) - (counsel-grep-or-swiper . ivy--regex-plus) - (counsel-rg . ivy--regex-plus) - (t . ivy--regex-ignore-order))) - (counsel-mode)) -#+end_src -*** WAIT Ivy posframe -:PROPERTIES: -:header-args:emacs-lisp: :tangle no -:END: -This makes ivy minibuffer windows use child frames. -Very nice eyecandy, but can get kinda annoying. -#+begin_src emacs-lisp -(use-package ivy-posframe - :hook (ivy-mode-hook . ivy-posframe-mode) - :straight t - :init - (setq ivy-posframe-parameters - '((left-fringe . 0) - (right-fringe . 0) - (background-color . "grey7"))) - - (setq ivy-posframe-display-functions-alist - '((t . ivy-posframe-display-at-window-center)))) -#+end_src -*** WAIT Counsel etags -:PROPERTIES: -:header-args:emacs-lisp: :tangle no -:END: -Counsel etags allows me to search generated tag files for tags. I -already have a function defined to generate the tags, so it's just -searching them which I find to be a bit of a hassle, and where this -package comes in. - -This has been replaced by [[*xref][xref]] which is inbuilt. -#+begin_src emacs-lisp -(use-package counsel-etags - :after counsel - :general - (search-leader - "t" #'counsel-etags-find-tag)) -#+end_src -** WAIT Ido -:PROPERTIES: -:header-args:emacs-lisp: :tangle no -:END: -Ido is a very old completion package that still works great to this -day. Though it is limited in its scope (and may thus be called a -completion add-on rather than a full on framework), it is still a very -powerful package. With the use of ido-completing-read+, it may be used -similarly to a fully fledged completion framework. - -#+begin_src emacs-lisp -(use-package ido - :demand t - :general - (general-def - :keymaps '(ido-buffer-completion-map - ido-file-completion-map - ido-file-dir-completion-map - ido-common-completion-map) - (kbd "M-j") #'ido-next-match - (kbd "M-k") #'ido-prev-match - (kbd "C-x o") #'evil-window-up) - :init - (setq ido-decorations - (list "{" "}" " \n" " ..." "[" "]" " [No match]" " [Matched]" - " [Not readable]" " [Too big]" " [Confirm]") - completion-styles '(flex partial-completion intials emacs22)) - (setq-default ido-enable-flex-matching t - ido-enable-dot-prefix t - ido-enable-regexp nil) - (with-eval-after-load "magit" - (setq magit-completing-read-function 'magit-ido-completing-read)) - :config - (ido-mode) - (ido-everywhere)) -#+end_src -*** Ido ubiquitous -Ido completing-read+ is a package that extends the ido package to work -with more text based functions. -#+begin_src emacs-lisp -(use-package ido-completing-read+ - :after ido - :config - (ido-ubiquitous-mode +1)) -#+end_src -** Amx -Amx is a fork of Smex that works to enhance the -execute-extended-command interface. It also provides support for ido -or ivy (though I'm likely to use ido here) and allows you to switch -between them. - -It provides a lot of niceties such as presenting the key bind when -looking for a command. - -#+begin_src emacs-lisp -(use-package amx - :config - (amx-mode)) -#+end_src -** Orderless -Orderless sorting method for completion, probably one of the best -things ever. -#+begin_src emacs-lisp -(use-package orderless - :after (ivy ido) - :config - (setf (alist-get t ivy-re-builders-alist) 'orderless-ivy-re-builder)) -#+end_src -** Completions-list -In case I ever use the completions list, some basic commands to look -around. -#+begin_src emacs-lisp -(use-package simple - :straight nil - :general - (nmmap - :keymaps 'completion-list-mode-map - "l" #'next-completion - "h" #'previous-completion - "ESC" #'delete-completion-window - "q" #'quit-window - "RET" #'choose-completion) - :config - (with-eval-after-load "evil" - (setq evil-emacs-state-modes (cl-remove-if - #'(lambda (x) (eq 'completions-list-mode x)) - evil-emacs-state-modes)) - (add-to-list 'evil-normal-state-modes 'completions-list-mode))) -#+end_src -** Company -Company is the auto complete system I use. I don't like having heavy -setups for company as it only makes it slower to use. In this case, -just setup some evil binds for company. -#+begin_src emacs-lisp -(use-package company - :straight t - :hook - (prog-mode-hook . company-mode) - (eshell-mode-hook . company-mode) - :general - (imap - "C-SPC" #'company-complete - "M-j" #'company-select-next - "M-k" #'company-select-previous)) -#+end_src -* Pretty symbols -Prettify symbols mode allows for users to declare 'symbols' that -replace text within certain modes. Though this may seem like useless -eye candy, it has aided my comprehension and speed of recognition -(recognising symbols is easier than words). - -Essentially a use-package keyword which makes declaring pretty symbols -for language modes incredibly easy. Checkout my [[C/C++][C/C++]] configuration -for an example. -#+begin_src emacs-lisp -(use-package prog-mode - :straight nil - :init - (setq prettify-symbols-unprettify-at-point t) - :config - (with-eval-after-load "use-package-core" - (add-to-list 'use-package-keywords ':pretty) - (defun use-package-normalize/:pretty (_name-symbol _keyword args) - args) - - (defun use-package-handler/:pretty (name _keyword args rest state) - (use-package-concat - (use-package-process-keywords name rest state) - (mapcar - #'(lambda (arg) - (let ((mode (car arg)) - (rest (cdr arg))) - `(add-hook - ',mode - #'(lambda nil - (setq prettify-symbols-alist ',rest) - (prettify-symbols-mode))))) - args))))) -#+end_src - -Here's a collection of keywords and possible associated symbols for -any prog language of choice. Mostly for reference and copying. -#+begin_example -("null" . "Ø") -("list" . "ℓ") -("string" . "𝕊") -("true" . "⊤") -("false" . "⊥") -("char" . "ℂ") -("int" . "ℤ") -("float" . "ℝ") -("!" . "¬") -("&&" . "∧") -("||" . "∨") -("for" . "∀") -("return" . "⟼") -("print" . "ℙ") -("lambda" . "λ") -#+end_example -* Window management -Emacs' default window management is quite bad, eating other windows on -a whim and not particularly caring for the current window setup. -Thankfully you can change this via the ~display-buffer-alist~ which -matches buffer names with how the window for the buffer should be -displayed. I add a use-package keyword to make ~display-buffer-alist~ -records within a use-package call. - -I have no idea whether it's optimal AT ALL, but it works for me. - -2024-04-23: Found this option ~switch-to-buffer-obey-display-actions~ -which makes manual buffer switches obey the same constraints via -~display-buffer-alist~ as creating the buffer automatically. -#+begin_src emacs-lisp -(use-package window - :straight nil - :general - (buffer-leader - "b" #'switch-to-buffer - "d" #'kill-current-buffer - "K" #'kill-buffer - "j" #'next-buffer - "k" #'previous-buffer - "D" '(+oreo/clean-buffer-list :which-key "Kill most buffers")) - :init - (setq switch-to-buffer-obey-display-actions t) - (with-eval-after-load "use-package-core" - (add-to-list 'use-package-keywords ':display) - (defun use-package-normalize/:display (_name-symbol _keyword args) - args) - - (defun use-package-handler/:display (name _keyword args rest state) - (use-package-concat - (use-package-process-keywords name rest state) - (mapcar - #'(lambda (arg) - `(add-to-list 'display-buffer-alist - ',arg)) - args))))) -#+end_src -** Some display records -Using the ~:display~ keyword, setup up some ~display-buffer-alist~ -records. This is mostly for packages that aren't really configured -(like [[info:woman][woman]]) or packages that were configured before -(like [[Ivy][Ivy]]). -#+begin_src emacs-lisp -(use-package window - :straight nil - :defer t - :display - ("\\*Process List\\*" - (display-buffer-at-bottom) - (window-height . 0.25)) - - ("\\*\\(Ido \\)?Completions\\*" - (display-buffer-in-side-window) - (window-height . 0.25) - (side . bottom)) - - ("\\*ivy-occur.*" - (display-buffer-at-bottom) - (window-height . 0.25)) - - ("\\*Async Shell Command\\*" - (display-buffer-at-bottom) - (window-height . 0.25))) -#+end_src -* Tabs -Tabs in vscode are just like buffers in Emacs but way slower and -harder to use. Tabs in Emacs are essentially window layouts, similar -to instances in Tmux. With this setup I can use tabs quite -effectively. - -#+begin_src emacs-lisp -(use-package tab-bar - :defer t - :straight nil - :init - (setq tab-bar-show 1) - :config - (tab-bar-mode) - :general - (tab-leader - "t" #'tab-switch - "j" #'tab-next - "k" #'tab-previous - "h" #'tab-move-to - "l" #'tab-move - "n" #'tab-new - "c" #'tab-close - "d" #'tab-close - "f" #'tab-detach - "w" #'tab-window-detach - "r" #'tab-rename) - (mode-leader - "t" #'toggle-tab-bar-mode-from-frame)) -#+end_src -* Auto typing -Snippets are a pretty nice way of automatically inserting code. Emacs -provides a ton of packages by default to do this, but there are great -packages to install as well. - -Abbrevs and skeletons make up a popular solution within Emacs default. -Abbrevs are for simple expressions wherein the only input is the key, -and the output is some Elisp function. They provide a lot of inbuilt -functionality and are quite useful. Skeletons, on the other hand, are -for higher level insertions - -The popular external solution is Yasnippet. Yasnippet is a great -package for snippets, which I use heavily in programming and org-mode. -I setup here the global mode for yasnippet and a collection of -snippets for ease of use. -** Abbrevs -Just define a few abbrevs for various date-time operations. Also -define a macro that will assume a function for the expansion, helping -with abstracting a few things away. -#+begin_src emacs-lisp -(use-package abbrev - :straight nil - :hook - (prog-mode-hook . abbrev-mode) - (text-mode-hook . abbrev-mode) - :init - (defmacro +abbrev/define-abbrevs (abbrev-table &rest abbrevs) - `(progn - ,@(mapcar #'(lambda (abbrev) - `(define-abbrev - ,abbrev-table - ,(car abbrev) - "" - (proc (insert ,(cadr abbrev))))) - abbrevs))) - (setq save-abbrevs nil) - :config - (+abbrev/define-abbrevs - global-abbrev-table - ("sdate" - (format-time-string "%Y-%m-%d" (current-time))) - ("stime" - (format-time-string "%H:%M:%S" (current-time))) - ("sday" - (format-time-string "%A" (current-time))) - ("smon" - (format-time-string "%B" (current-time))))) -#+end_src -** WAIT Skeletons -:PROPERTIES: -:header-args:emacs-lisp: :tangle no -:END: -Defines a macro for generating a skeleton + abbrev for a given mode. -Doesn't sanitise inputs because I assume callers are /rational/ actors -who would *only* use this for their top level Emacs config. - -Honestly didn't find much use for this currently, so disabled. -#+begin_src emacs-lisp -(use-package skeleton - :straight nil - :after abbrev - :config - (defmacro +autotyping/gen-skeleton-abbrev (mode abbrev &rest skeleton) - (let* ((table (intern (concat (symbol-name mode) "-abbrev-table"))) - (skeleton-name (intern (concat "+skeleton/" (symbol-name mode) "/" abbrev)))) - `(progn - (define-skeleton - ,skeleton-name - "" - ,@skeleton) - (define-abbrev ,table - ,abbrev - "" - ',skeleton-name))))) -#+end_src -** Auto insert -Allows inserting text immediately upon creating a new buffer with a -given name. Supports skeletons for inserting text. To make it easier -for later systems to define their own auto inserts, I define a -~use-package~ keyword ~auto-insert~ which allows one to define an -entry for ~auto-insert-alist~. -#+begin_src emacs-lisp -(use-package autoinsert - :straight nil - :demand t - :hook (after-init-hook . auto-insert-mode) - :config - (with-eval-after-load "use-package-core" - (add-to-list 'use-package-keywords ':auto-insert) - (defun use-package-normalize/:auto-insert (_name-symbol _keyword args) - args) - (defun use-package-handler/:auto-insert (name _keyword args rest state) - (use-package-concat - (use-package-process-keywords name rest state) - (mapcar - #'(lambda (arg) - `(add-to-list - 'auto-insert-alist - ',arg)) - args))))) -#+end_src -** Yasnippet default -Look at the snippets [[file:../.config/yasnippet/snippets/][folder]] -for all snippets I've got. -#+begin_src emacs-lisp -(use-package yasnippet - :defer t - :hook - (prog-mode-hook . yas-minor-mode) - (text-mode-hook . yas-minor-mode) - :general - (insert-leader - "i" #'yas-insert-snippet) - :config - (yas-load-directory (no-littering-expand-etc-file-name "yasnippet/snippets"))) -#+end_src -** WAIT Hydra -:PROPERTIES: -:header-args:emacs-lisp: :tangle no -:END: -Hydra is a great package by =abo-abo= (yes the same guy who made ivy -and swiper) and I hope to use it later on in the config. There are -two use-package declarations here: one for ~hydra~ itself, and the -other for ~use-package-hydra~ which provides the keyword ~:hydra~ in -use-package declarations. -#+begin_src emacs-lisp -(use-package hydra - :straight t) - -(use-package use-package-hydra - :straight t) -#+end_src -- cgit v1.2.3-13-gbd6f