aboutsummaryrefslogtreecommitdiff
path: root/Emacs/.config
diff options
context:
space:
mode:
authorAryadev Chavali <aryadev@aryadevchavali.com>2024-06-22 02:26:08 +0100
committerAryadev Chavali <aryadev@aryadevchavali.com>2024-06-22 02:26:08 +0100
commita89353eeb8727e31baa6093817be37583a34c41e (patch)
tree8267afbbd58d20cad7a330fb7a67393b998cd13e /Emacs/.config
parent3ef303fb670303571999aa5b9765ea91ad02ce56 (diff)
downloaddotfiles-a89353eeb8727e31baa6093817be37583a34c41e.tar.gz
dotfiles-a89353eeb8727e31baa6093817be37583a34c41e.tar.bz2
dotfiles-a89353eeb8727e31baa6093817be37583a34c41e.zip
Tons of changes
Diffstat (limited to 'Emacs/.config')
-rw-r--r--Emacs/.config/emacs/config.org243
-rw-r--r--Emacs/.config/emacs/early-init.el1
-rw-r--r--Emacs/.config/emacs/elisp/eshell-additions.el25
-rw-r--r--Emacs/.config/emacs/elisp/personal-primary-theme.el14
-rw-r--r--Emacs/.config/emacs/elisp/search.el6
5 files changed, 206 insertions, 83 deletions
diff --git a/Emacs/.config/emacs/config.org b/Emacs/.config/emacs/config.org
index a9829c2..ad42f8b 100644
--- a/Emacs/.config/emacs/config.org
+++ b/Emacs/.config/emacs/config.org
@@ -9,21 +9,32 @@
#+latex_class_options: [a4paper,12pt]
* Introduction
+:PROPERTIES:
+:header-args:emacs-lisp: :tangle config.el :results none
+:END:
Welcome to my Emacs configuration. You may be confused by the fact
it's a readable document rather than some code; this file serves as
both documentation *and* code. Here's an example of some Emacs Lisp
code:
#+begin_src emacs-lisp
-;; Copyright (C) 2024 Aryadev Chavali
-;; All rights reserved. You may not distribute or modify this code
-;; without explicit legal permission from the author "Aryadev Chavali"
+;;; config.el --- Compiled configuration from config.org -*- lexical-binding: t; -*-
+
+;; Copyright (C) 2024 Aryadev Chavali
+
+;; Author: Aryadev Chavali <aryadev@aryadevchavali.com>
+;; You may distribute and modify this code under the terms of the MIT
+;; license. You should have received a copy of the MIT license with
+;; this file. If not, please write to: aryadev@aryadevchavali.com.
+
+;;; Commentary:
;; Welcome to my Emacs configuration. This file is considered
;; volatile i.e. any edits made to this file will be overwritten if
;; and when the configuration is compiled again.
;; To propagate edits from this file to the literate document, call
;; (org-babel-detangle) while in the file.
+;;; Code:
#+end_src
This is an Emacs Lisp code block, something you will see a *LOT* of
@@ -55,6 +66,7 @@ Let's setup a few things:
+ Backup files (~backup-directory-alist~)
+ Refreshing buffers when a change occurs (~auto-revert-mode~)
+ Yes or no questions being less painful (~y-or-n-p~)
++ Make the clipboard work seamlessly with the clipboard
#+begin_src emacs-lisp
(use-package emacs
@@ -66,7 +78,8 @@ Let's setup a few things:
save-buffer-coding-system 'utf-8-unix
backup-directory-alist `(("." . ,(no-littering-expand-var-file-name "saves/")))
global-auto-revert-non-file-buffers t
- auto-revert-verbose nil)
+ auto-revert-verbose nil
+ select-enable-clipboard t)
:config
(fset 'yes-or-no-p 'y-or-n-p)
(global-auto-revert-mode))
@@ -219,7 +232,7 @@ Make font size bigger on my laptop and smaller on my desktop.
:config
(+oreo/sys-name-cond
("newboy" (set-face-attribute 'default nil :height 145))
- ("oldboy" (set-face-attribute 'default nil :height 130))))
+ ("oldboy" (set-face-attribute 'default nil :height 135))))
#+end_src
** Startup screen
The default startup screen is quite bad in all honesty. While for a
@@ -514,11 +527,15 @@ Setup the evil package, with some opinionated keybindings:
more
- Switch ~evil-goto-mark~ and ~evil-goto-mark-line~ as I'd rather have
the global one closer to the home row
+- Push the mark when exiting visual mode
+ - On entering visual mode, the mark is set, so by pushing it when
+ exiting we can use the mark-ring for other stuff
- Use 'T' character as an action for transposing objects
#+begin_src emacs-lisp
(use-package evil
:demand t
:straight t
+ :hook (evil-visual-state-entry-hook . push-mark)
:general
(leader
"w" '(evil-window-map :which-key "Window")
@@ -532,10 +549,14 @@ Setup the evil package, with some opinionated keybindings:
"zC" #'hs-hide-level
"zO" #'hs-show-all
"'" #'evil-goto-mark
- "`" #'evil-goto-mark-line
- "C-w" #'evil-window-map
+ "`" #'evil-goto-mark-line)
+
+ (general-def
+ :keymaps 'override
+ :states '(normal motion visual)
"gu" #'evil-upcase
"gU" #'evil-downcase
+ "M-y" #'yank-pop
"T" nil)
(nmmap
@@ -735,11 +756,9 @@ looking for a command.
#+begin_src emacs-lisp
(use-package amx
:straight t
- :defer t
+ :hook (after-init-hook . amx-mode)
:init
- (setq amx-backend 'ivy)
- :config
- (amx-mode))
+ (setq amx-backend 'ivy))
#+end_src
*** Orderless
Orderless sorting method for completion, probably one of the best
@@ -767,10 +786,7 @@ around.
"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)))
+ (evil-set-initial-state 'completions-list-mode 'normal)))
#+end_src
*** Company
Company is the auto complete system I use. I don't like having heavy
@@ -1100,6 +1116,9 @@ really need this in my config at all times. Enable when needed.
:defer t)
#+end_src
** Hl-line
+:PROPERTIES:
+:header-args:emacs-lisp: :tangle no
+:END:
Highlights the current line.
#+begin_src emacs-lisp
(use-package hl-line
@@ -1335,26 +1354,13 @@ at last.
:config
(save-place-mode))
#+end_src
-** Rot13
-ROT13 encoding is a pretty simple cipher; fun to make decoders and
-encoders for. Emacs has default support for it, to the point where it
-can display files with the encoding without changing the underlying
-text. That's what this is mainly for.
-
-#+begin_src emacs-lisp
-(use-package rot13
- :defer t
- :general
- (mode-leader
- "r" #'toggle-rot13-mode))
-#+end_src
** Licensing
Loads [[file:elisp/license.el][license.el]] for inserting licenses.
Licenses are important for distribution and attribution to be defined
clearly.
#+begin_src emacs-lisp
(use-package license
- :defer t
+ :demand t
:load-path "elisp/"
:general
(insert-leader
@@ -1400,9 +1406,21 @@ directories particularly efficiently.
:load-path "elisp/"
:general
(file-leader
- "P" #'+search/find-file
+ "p" #'+search/find-file
"S" #'+search/search-all))
#+end_src
+** Separedit
+Edit anything anywhere all at once!
+#+begin_src emacs-lisp
+(use-package separedit
+ :defer t
+ :straight t
+ :general
+ (leader "e" #'separedit)
+ :init
+ (setq separedit-default-mode 'org-mode
+ separedit-remove-trailing-spaces-in-comment t))
+#+end_src
* Applications
Emacs is basically an operating system whose primary datatype is text.
Applications are interfaces/environments which serve a variety of
@@ -1554,7 +1572,8 @@ Here I setup dired with a few niceties
:init
(setq-default dired-listing-switches "-AFBlu --group-directories-first"
dired-omit-files "^\\."
- dired-dwim-target t)
+ dired-dwim-target t
+ dired-kill-when-opening-new-dired-buffer t)
(with-eval-after-load "evil-collection"
(evil-collection-dired-setup))
:general
@@ -1649,16 +1668,15 @@ easier than even using the mark based system.
** Eshell
*** Why Eshell?
Eshell is an integrated shell environment for Emacs, written in Emacs
-Lisp. I argue that it is the best shell/command interpreter to use in
-Emacs.
+Lisp. I argue henceforth that it is the best shell/command
+interpreter to use in Emacs.
-Eshell is unlike the alternatives in Emacs as it's a /shell/ first,
-not a terminal emulator. It has the ability to spoof some aspects of a
-terminal emulator (through the shell parser), but it is NOT a terminal
-emulator.
+Eshell is unlike the other alternatives in Emacs as it's a /shell/
+first, not a terminal emulator, with the ability to spoof some aspects
+of a terminal emulator (through the shell parser).
-The killer benefits of eshell (which would appeal to Emacs users) are
-a direct result of eshell being written in Emacs lisp:
+The killer benefits of eshell (which would appeal particularly to an
+Emacs user) are a direct result of eshell being written in Emacs Lisp:
- incredible integration with Emacs utilities (such as ~dired~,
~find-file~, any read functions, etc)
- very extensible, easy to write new commands which leverage Emacs
@@ -1700,11 +1718,8 @@ them.
#+begin_src emacs-lisp
(use-package eshell
:defer t
- :general
- (shell-leader
- "t" #'eshell)
:display
- ("\\*e?shell\\*"
+ ("\\*.*eshell\\*"
(display-buffer-at-bottom)
(window-height . 0.33))
:init
@@ -1715,12 +1730,14 @@ them.
'eshell-mode-hook
(proc
(interactive)
+ (nmap
+ :keymaps 'eshell-mode-map
+ "0" #'eshell-bol)
(general-def
:states '(normal insert)
:keymaps 'eshell-mode-map
- "0" #'eshell-bol
- "M-j" #'eshell-next-matching-input-from-input
- "M-k" #'eshell-previous-matching-input-from-input)
+ "C-j" #'eshell-next-matching-input-from-input
+ "C-k" #'eshell-previous-matching-input-from-input)
(local-leader
:keymaps 'eshell-mode-map
"c" (proc (interactive) (eshell/clear)
@@ -1743,8 +1760,7 @@ internals, just standard old Emacs packages.
:load-path "elisp/"
:config
(defun +eshell/banner-message ()
- (concat (shell-command-to-string "~/.local/scripts/cowfortune")
- "\n"))
+ (concat (shell-command-to-string "cowfortune") "\n"))
(setq eshell-prompt-regexp (format "^%s" +eshell-prompt/user-prompt)
eshell-prompt-function #'+eshell-prompt/make-prompt
eshell-banner-message '(+eshell/banner-message)))
@@ -1762,11 +1778,24 @@ if I loaded this ~:after~ eshell then the first instance has no
knowledge of the new additions.
#+begin_src emacs-lisp
(use-package eshell-additions
+ :defer t
:load-path "elisp/"
:general
+ (shell-leader
+ "t" #'+eshell/open)
(leader
"T" #'+eshell/at-cwd))
#+end_src
+*** Eshell syntax highlighting
+This package external package adds syntax highlighting to eshell
+(disabling it for remote work). Doesn't require a lot of config
+thankfully.
+#+begin_src emacs-lisp
+(use-package eshell-syntax-highlighting
+ :straight t
+ :after eshell
+ :hook (eshell-mode-hook . eshell-syntax-highlighting-mode))
+#+end_src
** WAIT Elfeed
:PROPERTIES:
:header-args:emacs-lisp: :tangle no
@@ -2122,7 +2151,7 @@ limit), so set it for specific modes need the help.
(text-mode-hook . whitespace-mode)
:init
(setq whitespace-style '(face empty spaces tabs newline trailing lines-char
- tab-mark missing-newline-at-eof)
+ tab-mark)
whitespace-line-column 80))
#+end_src
** Set auto-fill-mode for all text-modes
@@ -2233,7 +2262,7 @@ has very little overhead to work there.
(display-buffer-at-bottom)
(window-height . 0.25))
:init
- (setq-default flycheck-check-syntax-automatically '(save new-line mode-enabled))
+ (setq-default flycheck-check-syntax-automatically '(save idle-change new-line mode-enabled))
:config
(with-eval-after-load "evil-collection"
(evil-collection-flycheck-setup)))
@@ -2454,8 +2483,21 @@ quickly generate them in C/C++ projects.
:straight t
:defer t
:general
- (nmmap
- "K" #'devdocs-lookup))
+ (file-leader
+ "d" #'devdocs-lookup))
+#+end_src
+** rainbow-delimiters
+Makes colours delimiters (parentheses) based on their depth in an
+expression. Rainbow flag in your Lisp source code.
+#+begin_src emacs-lisp
+(use-package rainbow-delimiters
+ :defer t
+ :straight t
+ :general
+ (mode-leader "r" #'rainbow-delimiters-mode)
+ :hook
+ (lisp-mode-hook . rainbow-delimiters-mode)
+ (emacs-lisp-mode-hook . rainbow-delimiters-mode))
#+end_src
* Org mode
Org is, at its most basic, a markup language. =org-mode= is a major
@@ -2681,7 +2723,7 @@ them. This allows me to search my configuration pretty quickly.
+org/search-config-headings)
:general
(file-leader
- "p" #'+org/search-config-headings)
+ "P" #'+org/search-config-headings)
(search-leader
:keymaps 'org-mode-map
"I" #'+org/search-headings)
@@ -2972,22 +3014,16 @@ OBJECTS=$(CODE:$(SRC)/%.c=$(DIST)/%.o)
DEPDIR:=$(DIST)/dependencies
DEPS:=$(CODE:$(SRC)/%.c=$(DEPDIR):%.d) $(DEPDIR)/main.d
-TERM_YELLOW:=$(shell echo -e \"\\e[0;33m\")
-TERM_GREEN:=$(shell echo -e \"\\e[0;32m\")
-TERM_RESET:=$(shell echo -e \"\\e[0;0m\")
-
.PHONY: all
all: $(OUT)
$(OUT): $(DIST)/$(OUT)
$(DIST)/$(OUT): $(OBJECTS) $(DIST)/main.o | $(DIST)
- @$(CC) $(CFLAGS) $^ -o $@ $(LIBS)
- @echo \"$(TERM_GREEN)$@$(TERM_RESET): $^\"
+ $(CC) $(CFLAGS) $^ -o $@ $(LIBS)
$(DIST)/%.o: $(SRC)/%.c | $(DIST) $(DEPDIR)
- @$(CC) $(CFLAGS) $(DEPFLAGS) $(DEPDIR)/$*.d -c $< -o $@ $(LIBS)
- @echo \"$(TERM_YELLOW)$@$(TERM_RESET): $<\"
+ $(CC) $(CFLAGS) $(DEPFLAGS) $(DEPDIR)/$*.d -c $< -o $@ $(LIBS)
.PHONY: run
run: $(DIST)/$(OUT)
@@ -2995,13 +3031,13 @@ run: $(DIST)/$(OUT)
.PHONY:
clean:
- @rm -rfv $(DIST)/*
+ rm -rfv $(DIST)/*
$(DIST):
- @mkdir -p $(DIST)
+ mkdir -p $(DIST)
$(DEPDIR):
- @mkdir -p $(DEPDIR)
+ mkdir -p $(DEPDIR)
-include $(DEPS)
"
@@ -3152,7 +3188,7 @@ my dotfiles).
:general
(code-leader
:keymaps '(c-mode-map c++-mode-map)
- "f" #'+code/clang-format-region-or-buffer)
+ "f" #'clang-format-buffer)
:config
(define-minor-mode clang-format-mode
"On save formats the current buffer via clang-format."
@@ -3492,29 +3528,24 @@ Here I just setup Sly to use ~sbcl~.
(display-buffer-at-bottom)
(window-height . 0.25))
:config
- (evil-set-initial-state 'sly-db-mode 'emacs)
+ (evil-set-initial-state 'sly-db-mode 'normal)
(with-eval-after-load "org"
(setq-default org-babel-lisp-eval-fn #'sly-eval))
(with-eval-after-load "company"
(add-hook 'sly-mrepl-hook #'company-mode))
:general
(shell-leader
- "s" #'sly-mrepl)
+ "s" #'sly)
(nmap
:keymaps 'lisp-mode-map
"gr" #'sly-eval-buffer
"gd" #'sly-edit-definition
"gR" #'sly-who-calls)
(local-leader
- :keymaps '(sly-mrepl-mode-map lisp-mode-map)
+ :keymaps 'lisp-mode-map
"a" '(sly-apropos :which-key "Apropos")
"d" '(sly-describe-symbol :which-key "Describe symbol")
- "D" '(sly-documentation-lookup :which-key "Lookup on lispworks"))
- (local-leader
- :keymaps 'sly-mrepl-mode-map
- "s" '(sly-mrepl-shortcut :which-key "Shortcut"))
- (local-leader
- :keymaps 'lisp-mode-map
+ "D" '(sly-documentation-lookup :which-key "Lookup on lispworks")
"l" '(sly-load-file :which-key "Load file")
"c" '(sly-compile-defun :which-key "Compile defun")
"C" '(sly-compile-file :which-key "Compile file")
@@ -3527,9 +3558,67 @@ Here I just setup Sly to use ~sbcl~.
"f" #'sly-eval-defun
"r" #'sly-eval-region)
(nmap
+ :keymaps 'sly-mrepl-mode-map
+ "M-j" #'sly-mrepl-next-input-or-button
+ "M-k" #'sly-mrepl-previous-input-or-button)
+ (local-leader
+ :keymaps 'sly-mrepl-mode-map
+ "s" '(sly-mrepl-shortcut :which-key "Shortcut"))
+ (nmap
+ :keymaps 'sly-db-mode-map
+ "\C-i" 'sly-db-cycle
+ "g?" 'describe-mode
+ "S" 'sly-db-show-frame-source
+ "e" 'sly-db-eval-in-frame
+ "d" 'sly-db-pprint-eval-in-frame
+ "D" 'sly-db-disassemble
+ "i" 'sly-db-inspect-in-frame
+ "gj" 'sly-db-down
+ "gk" 'sly-db-up
+ (kbd "C-j") 'sly-db-down
+ (kbd "C-k") 'sly-db-up
+ "]]" 'sly-db-details-down
+ "[[" 'sly-db-details-up
+ (kbd "M-j") 'sly-db-details-down
+ (kbd "M-k") 'sly-db-details-up
+ "gg" 'sly-db-beginning-of-backtrace
+ "G" 'sly-db-end-of-backtrace
+ "t" 'sly-db-toggle-details
+ "gr" 'sly-db-restart-frame
+ "I" 'sly-db-invoke-restart-by-name
+ "R" 'sly-db-return-from-frame
+ "c" 'sly-db-continue
+ "s" 'sly-db-step
+ "n" 'sly-db-next
+ "o" 'sly-db-out
+ "b" 'sly-db-break-on-return
+ "a" 'sly-db-abort
+ "q" 'sly-db-quit
+ "A" 'sly-db-break-with-system-debugger
+ "B" 'sly-db-break-with-default-debugger
+ "P" 'sly-db-print-condition
+ "C" 'sly-db-inspect-condition
+ "g:" 'sly-interactive-eval
+ "0" 'sly-db-invoke-restart-0
+ "1" 'sly-db-invoke-restart-1
+ "2" 'sly-db-invoke-restart-2
+ "3" 'sly-db-invoke-restart-3
+ "4" 'sly-db-invoke-restart-4
+ "5" 'sly-db-invoke-restart-5
+ "6" 'sly-db-invoke-restart-6
+ "7" 'sly-db-invoke-restart-7
+ "8" 'sly-db-invoke-restart-8
+ "9" 'sly-db-invoke-restart-9)
+ (nmap
:keymaps 'sly-inspector-mode-map
"q" #'sly-inspector-quit))
#+end_src
+*** Sly-ASDF
+#+begin_src emacs-lisp
+(use-package sly-asdf
+ :straight t
+ :after sly)
+#+end_src
*** Emacs lisp
#+begin_src emacs-lisp
(use-package elisp-mode
@@ -3545,10 +3634,10 @@ Here I just setup Sly to use ~sbcl~.
(">=" . "≥")
("defun" . "ƒ")
("loop" . "Σ")
- ("some" . "∃")
- ("every" . "∀")
("mapcar" . "→")
- ("loop" . "⇒"))
+ ("reduce" . "↓")
+ ("some" . "∃")
+ ("every" . "∀"))
(emacs-lisp-mode-hook
("lambda" . "λ")
("t" . "⊨")
diff --git a/Emacs/.config/emacs/early-init.el b/Emacs/.config/emacs/early-init.el
index f006057..4c3d59c 100644
--- a/Emacs/.config/emacs/early-init.el
+++ b/Emacs/.config/emacs/early-init.el
@@ -35,7 +35,6 @@
(setq-default
default-frame-alist '((menu-bar-lines . 0)
(tool-bar-lines . 0)
- (tab-bar-lines . 0)
(scroll-bar-lines . 0)
(left-fringe . 0)
(right-fringe . 0)
diff --git a/Emacs/.config/emacs/elisp/eshell-additions.el b/Emacs/.config/emacs/elisp/eshell-additions.el
index 94c948f..d56dc99 100644
--- a/Emacs/.config/emacs/elisp/eshell-additions.el
+++ b/Emacs/.config/emacs/elisp/eshell-additions.el
@@ -53,5 +53,30 @@
(eshell/cd dir)
(eshell-send-input))))
+(defun +eshell/--current-instances ()
+ (cl-loop for buffer being the buffers
+ if (with-current-buffer buffer
+ (eq major-mode 'eshell-mode))
+ collect
+ (cons (buffer-name buffer) buffer)))
+
+(defun +eshell/open (&optional ARG)
+ "If no arg is given, run EShell as per usual.
+If an arg is given, then interactively open a new Eshell instance
+or a currently opened one, naming it in the process."
+ (interactive "P")
+ (if (null ARG)
+ (eshell)
+ (let* ((current-instances (+eshell/--current-instances))
+ (answer (completing-read "Enter name: " (mapcar #'car current-instances)))
+ (result (assoc answer current-instances)))
+ (cond
+ (result (switch-to-buffer (cdr result)))
+ ((not (string= answer ""))
+ (let ((eshell-buffer-name (format "*%s-eshell*" answer)))
+ (eshell)))
+ (t
+ (eshell))))))
+
(provide 'eshell-additions)
;;; eshell-additions.el ends here
diff --git a/Emacs/.config/emacs/elisp/personal-primary-theme.el b/Emacs/.config/emacs/elisp/personal-primary-theme.el
index 22a1faa..d3aa22f 100644
--- a/Emacs/.config/emacs/elisp/personal-primary-theme.el
+++ b/Emacs/.config/emacs/elisp/personal-primary-theme.el
@@ -51,8 +51,8 @@
'(link-visited ((t (:foreground "violet" :inherit (link)))))
'(match ((t (:background "RoyalBlue3"))))
'(minibuffer-prompt ((t (:foreground "cyan"))))
- '(mode-line ((t (:box t :foreground "LightSkyBlue" :background "black"))))
- '(mode-line-inactive ((t (:box nil :weight light :foreground "CadetBlue" :background "grey7"))))
+ '(mode-line ((t (:box t :foreground "LightSkyBlue" :background "black" :inherit (default)))))
+ '(mode-line-inactive ((t (:box nil :weight light :foreground "CadetBlue" :background "grey7" :inherit (default)))))
'(mode-line-buffer-id ((t (:weight bold))))
'(mode-line-emphasis ((t (:weight bold))))
'(next-error ((t (:inherit (region)))))
@@ -67,6 +67,16 @@
'(pdf-isearch-batch ((t (:foreground "black" :background "white"))))
'(query-replace ((t (:inherit (isearch)))))
'(region ((t (:extend t :background "grey25"))))
+ '(rainbow-delimiters-depth-1-face ((t (:extend t :foreground "red"))))
+ '(rainbow-delimiters-depth-2-face ((t (:extend t :foreground "darkorange"))))
+ '(rainbow-delimiters-depth-3-face ((t (:extend t :foreground "yellow"))))
+ '(rainbow-delimiters-depth-4-face ((t (:extend t :foreground "green"))))
+ '(rainbow-delimiters-depth-5-face ((t (:extend t :foreground "DeepSkyBlue"))))
+ '(rainbow-delimiters-depth-6-face ((t (:extend t :foreground "purple"))))
+ '(rainbow-delimiters-depth-7-face ((t (:extend t :foreground "violet"))))
+ '(rainbow-delimiters-mismatched-face ((t (:extend t :foreground "white" :background "red1"))))
+ '(rainbow-delimiters-unmatched-face ((t (:inherit rainbow-delimiters-mismatched-face))))
+ '(rainbow-delimiters-base-error-face ((t (:inherit rainbow-delimiters-mismatched-face))))
'(shadow ((((class color grayscale) (min-colors 88) (background light)) (:foreground "grey50"))
(((class color grayscale) (min-colors 88) (background dark)) (:foreground "grey70"))
(((class color) (min-colors 8) (background light)) (:foreground "green"))
diff --git a/Emacs/.config/emacs/elisp/search.el b/Emacs/.config/emacs/elisp/search.el
index 922d9a6..4b0097c 100644
--- a/Emacs/.config/emacs/elisp/search.el
+++ b/Emacs/.config/emacs/elisp/search.el
@@ -42,7 +42,8 @@ Returns a list of files with the directory preprended to them."
names)))
(defun +search/get-all-candidates ()
- (string-join
+ (cl-reduce
+ #'(lambda (x y) (append x y))
(mapcar #'(lambda (directory)
(+search/get-candidates (expand-file-name directory)))
+search/directories)))
@@ -58,8 +59,7 @@ Returns a list of files with the directory preprended to them."
(string-join
(mapcar
#'(lambda (x) (concat "\"" x "\""))
- (cl-remove-if #'directory-name-p (+search/get-all-candidates)))
- " "))
+ (cl-remove-if #'directory-name-p (+search/get-all-candidates)))))
(defun +search/search-all ()
(interactive)