about summary refs log tree commit diff
path: root/configs/.emacs
diff options
context:
space:
mode:
authorWilliam Carroll <wpcarro@gmail.com>2017-01-24T20·11-0500
committerWilliam Carroll <wpcarro@gmail.com>2017-01-24T20·15-0500
commita328b7e240dc6f6edf160ad163dbed68ef95c2ab (patch)
tree1e0bf5d9d7ea769fb7efae365fa849433b895e46 /configs/.emacs
parent2076f42c00fb92521ec9fb6ad2a1d5caa8e01370 (diff)
Updates config to use-package
Diffstat (limited to 'configs/.emacs')
-rw-r--r--configs/.emacs487
1 files changed, 265 insertions, 222 deletions
diff --git a/configs/.emacs b/configs/.emacs
index 71b43f730c80..f9278a09aff4 100644
--- a/configs/.emacs
+++ b/configs/.emacs
@@ -1,4 +1,4 @@
-; William Carroll's Emacs configuration
+;;; William Carroll's Emacs configuration
 
 
 ;; From `https://github.com/melpa/melpa`
@@ -20,14 +20,14 @@
  '(command-log-mode-window-size 50)
  '(custom-safe-themes
    (quote
-    ("9d91458c4ad7c74cf946bd97ad085c0f6a40c370ac0a1cbeb2e3879f15b40553" "6254372d3ffe543979f21c4a4179cd819b808e5dd0f1787e2a2a647f5759c1d1" "8ec2e01474ad56ee33bc0534bdbe7842eea74dccfb576e09f99ef89a705f5501" "5b24babd20e58465e070a8d7850ec573fe30aca66c8383a62a5e7a3588db830b" "eb0a314ac9f75a2bf6ed53563b5d28b563eeba938f8433f6d1db781a47da1366" "3d47d88c86c30150c9a993cc14c808c769dad2d4e9d0388a24fee1fbf61f0971" default)))
+    ("0f0db69b7a75a7466ef2c093e127a3fe3213ce79b87c95d39ed1eccd6fe69f74" "08b8807d23c290c840bbb14614a83878529359eaba1805618b3be7d61b0b0a32" "9d91458c4ad7c74cf946bd97ad085c0f6a40c370ac0a1cbeb2e3879f15b40553" "6254372d3ffe543979f21c4a4179cd819b808e5dd0f1787e2a2a647f5759c1d1" "8ec2e01474ad56ee33bc0534bdbe7842eea74dccfb576e09f99ef89a705f5501" "5b24babd20e58465e070a8d7850ec573fe30aca66c8383a62a5e7a3588db830b" "eb0a314ac9f75a2bf6ed53563b5d28b563eeba938f8433f6d1db781a47da1366" "3d47d88c86c30150c9a993cc14c808c769dad2d4e9d0388a24fee1fbf61f0971" default)))
  '(evil-shift-width 2)
  '(mouse-wheel-mode nil)
  '(neo-window-fixed-size nil)
  '(neo-window-width 35)
  '(package-selected-packages
    (quote
-    (evil-leader flycheck-mix flycheck-elixir evil-matchit typescript-mode evil-surround erlang elixir-mode golden-ratio flycheck-credo flycheck command-log-mode atom-one-dark-theme exec-path-from-shell clues-theme gotham-theme dracula-theme zenburn-theme fill-column-indicator neotree evil helm-swoop iedit vimrc-mode helm-ispell transpose-frame helm-projectile helm-ack nyan-mode alchemist helm magit dockerfile-mode elm-mode ack)))
+    (doom-neotree doom-themes persp-mode use-package helm-projectile persp-projectile perspective projectile with-editor helm-core company helm-ag evil-leader flycheck-mix flycheck-elixir evil-matchit typescript-mode evil-surround erlang elixir-mode golden-ratio flycheck-credo flycheck command-log-mode atom-one-dark-theme exec-path-from-shell clues-theme gotham-theme dracula-theme zenburn-theme fill-column-indicator neotree evil iedit vimrc-mode helm-ispell transpose-frame helm-ack nyan-mode alchemist helm magit dockerfile-mode elm-mode ack)))
  '(popwin-mode t)
  '(popwin:popup-window-height 25)
  '(tool-bar-mode nil))
@@ -39,206 +39,201 @@
  '(hl-line ((t (:inherit nil)))))
 
 
-;; Colorscheme
-(load-theme 'atom-one-dark)
+;; All-the-fonts
+(use-package all-the-icons
+  :ensure t)
 
 
-;; Scrolling Settings
-(setq scroll-step 1)
-(setq scroll-conservatively 10000)
-
-
-;; Properly configure GUI Emacs to use $PATH values
-(when (memq window-system '(mac ns))
-  (exec-path-from-shell-initialize))
-
-
-;; Trim trailing whitespace on save
-(add-hook 'before-save-hook 'delete-trailing-whitespace)
-
-
-;; Emacs backup / autosave files
-;; (setq-default make-backup-files nil)
-(setq backup-directory-alist `(("." . "~/.emacs-tmp")))
-(setq auto-save-file-name-transforms `((".*" "~/.emacs-tmp/" t)))
+;; Doom Themes
+(use-package doom-themes
+  :ensure t
+  :init
+  (load-theme 'doom-one t)
+  (use-package doom-neotree)
+  (use-package doom-nlinum))
 
 
-;; Automatically follow symlinks
-(setq vc-follow-symlinks t)
-
-
-;; Enable autocompletion
-(add-hook 'after-init-hook 'global-company-mode)
-
-;; Remove company delay
-(setq-default company-idle-delay 0)
+;; Magit Settings
+(use-package magit
+  :ensure t
+  :bind (("C-x g" . magit-status)
+         ("C-x M-g" . magit-dispatch-popup)))
 
 
 ;; View stream of Emacs commands
-(require 'command-log-mode)
-(global-command-log-mode)
-
-
-;; Commenting / Uncommenting
-(global-set-key (kbd "C-x C-;") 'comment-or-uncomment-region)
+(use-package command-log-mode
+  :ensure t
+  :commands (global-command-log-mode))
 
 
 ;; Flycheck Settings
-(require 'flycheck)
-(add-hook 'after-init-hook 'global-flycheck-mode)
+(use-package flycheck
+  :ensure t)
 
 
-;; Elixir flycheck compile-time errors
-(require 'flycheck-mix)
-(require 'flycheck-credo)
-(eval-after-load 'flycheck (lambda () (flycheck-credo-setup) (flycheck-mix-setup)))
+;; Ansi Term
+(use-package term
+  :bind (:map term-mode-map
+         ("M-p" . term-send-up)
+         ("M-n" . term-send-down)
 
+         :map term-raw-map
+         ("C-h" . evil-window-left)
+         ("C-l" . evil-window-right)
+         ("C-k" . evil-window-up)
+         ("C-j" . evil-window-down)))
 
-;; Magit Settings
-(global-set-key (kbd "C-x g") 'magit-status)
-(global-set-key (kbd "C-x M-g") 'magit-dispatch-popup)
 
+;; Projectile Settings
+(use-package projectile
+  :ensure t
+  :commands (projectile-mode))
 
-;; Fullscreen settings
-(setq ns-use-native-fullscreen nil)
-(global-set-key (kbd "<s-return>") 'toggle-frame-fullscreen)
-
-
-;; Dired Settings
-(require 'dired)
-(define-key dired-mode-map (kbd "c") 'find-file)
-
-
-;; Helm Settings
-(require 'helm)
-(require 'helm-config)
-
-(global-set-key (kbd "C-c h") 'helm-command-prefix)
-(global-unset-key (kbd "C-x c"))
-
-(global-set-key (kbd "M-x") 'helm-M-x)
-(global-set-key (kbd "C-x C-f") 'helm-projectile)
-(global-set-key (kbd "M-y") 'helm-show-kill-ring)
-(global-set-key (kbd "C-x b") 'helm-mini)
-(global-set-key (kbd "C-x C-b") 'helm-buffers-list)
-(global-set-key (kbd "C-c h o") 'helm-swoop)
-
-(define-key helm-map (kbd "<tab>") 'helm-execute-persistent-action)
-(define-key helm-map (kbd "C-i") 'helm-execute-persistent-action)
-(define-key helm-map (kbd "C-z")  'helm-select-action)
-
-(setq helm-buffers-fuzzy-matching t
-      helm-recentf-fuzzy-match    t)
-
-(setq helm-semantic-fuzzy-match t
-      helm-imenu-fuzzy-match    t)
-
-(setq helm-locate-fuzzy-match t)
-
-(helm-mode 1)
 
+;; Evil Settings
+(use-package evil
+  :ensure t
+  :commands (evil-mode local-evil-mode)
+  :bind (:map evil-insert-state-map
+         ("<escape>" . evil-force-normal-state)
+         ("j k" . evil-force-normal-state)
+
+         :map evil-motion-state-map
+         ("<return>" . nil)
+         ("<tab>" . nil)
+         ("SPC" . nil)
+         ("M-." . nil)
+         ("/" . helm-do-ag-this-file)
+         ("?" . helm-do-ag-this-file)
+
+         :map evil-normal-state-map
+         ("<return>" . nil)
+         ("<tab>" . nil)
+         ("C-h" . evil-window-left)
+         ("C-l" . evil-window-right)
+         ("C-k" . evil-window-up)
+         ("C-j" . evil-window-down)
+         ("s" . nil)
+         ("s l" . evil-window-vsplit)
+         ("s j" . evil-window-split)
+         ("H" . evil-first-non-blank)
+         ("L" . evil-end-of-line))
+  :init
+  (setq evil-emacs-state-cursor '("red" box))
+  (setq evil-normal-state-cursor '("green" box))
+  (setq evil-visual-state-cursor '("orange" box))
+  (setq evil-insert-state-cursor '("red" bar))
+  (setq evil-replace-state-cursor '("red" bar))
+  (setq evil-operator-state-cursor '("red" hollow))
+  (global-evil-matchit-mode t)
+  (global-evil-surround-mode t)
+  (global-evil-leader-mode t))
+
+
+;; Evil Leader Settings
+(use-package evil-leader
+  :ensure t
+  :commands (global-evil-leader-mode)
+  :config
+  (evil-leader/set-leader "<SPC>")
+  (evil-leader/set-key
+    "x" 'helm-M-x
+    "<SPC>" 'mode-line-other-buffer
+    "n" 'neotree-project-dir
+    "b" 'helm-mini))
 
-;; Global search in projects
-(global-set-key (kbd "C-x p") 'helm-projectile-ack)
 
+;; Evil Match-it
+(use-package evil-matchit
+  :ensure t
+  :commands (global-evil-matchit-mode))
 
-;; Ansi Term Settings
-;; (define-key 'term-mode-map (kbd "C-h") 'window-left)
-;; (define-key 'term-mode-map (kbd "C-l") 'window-right)
-;; (define-key 'term-mode-map (kbd "C-k") 'window-up)
-;; (define-key 'term-mode-map (kbd "C-j") 'window-down)
 
+;; Evil Surround
+(use-package evil-surround
+  :ensure t
+  :commands (global-evil-surround-mode))
 
-;; disable popwin-mode in an active Helm session It should be disabled
-;; otherwise it will conflict with other window opened by Helm persistent
-;; action, such as *Help* window.
-(require 'popwin)
 
-(push '("^\*helm.+\*$" :regexp t) popwin:special-display-config)
-(add-hook 'helm-after-initialize-hook (lambda ()
-                                        (popwin:display-buffer helm-buffer t)
-                                        (popwin-mode -1)))
+;; Flycheck Mix Settings
+(use-package flycheck-mix
+  :ensure t
+  :init
+  (flycheck-mix-setup))
 
-;;  Restore popwin-mode after a Helm session finishes.
-(add-hook 'helm-cleanup-hook (lambda () (popwin-mode 1)))
 
-;; Popwin Helm-Swoop workaround
-(defvar helm-swoop-split-window-function
-  (lambda ($buf)
-    (display-buffer $buf)))
+;; Flycheck Credo Settings
+(use-package flycheck-credo
+  :ensure t
+  :init
+  (flycheck-credo-setup))
 
 
-;; Add 80 column marker
-(require 'whitespace)
-(setq whitespace-line-column 80) ;; limit line length
-(setq whitespace-style '(face lines-tail))
-(add-hook 'prog-mode-hook 'whitespace-mode)
+;; Popwin Settings
+(use-package popwin
+  :ensure t)
 
+(defun *-popwin-help-mode-off ()
+  "Turn `popwin-mode' off for *Help* buffers."
 
-;; Allow `C-x C-s` to write to unmodified buffers, allowing the file to be `touch`'d
-(set-buffer-modified-p t)
+  (when (boundp 'popwin:special-display-config)
+    (customize-set-variable 'popwin:special-display-config
+                            (delq 'help-mode popwin:special-display-config))))
 
+(defun *-popwin-help-mode-on ()
+  "Turn `popwin-mode' on for *Help* buffers."
 
-;; Git-Commit prog-mode
-;; (add-hook 'git-commit-mode 'prog-mode)
+  (when (boundp 'popwin:special-display-config)
+    (customize-set-variable 'popwin:special-display-config
+                            (add-to-list 'popwin:special-display-config 'help-mode nil #'eq))))
 
+(add-hook 'helm-minibuffer-set-up-hook #'*-popwin-help-mode-off)
+(add-hook 'helm-cleanup-hook #'*-popwin-help-mode-on)
 
-;; Projectile Settings
-(projectile-mode t)
-(setq projectile-completion-system 'helm)
-(helm-projectile-on)
-(setq projectile-switch-project-action 'helm-projectile)
+(setq display-buffer-function 'popwin:display-buffer)
+(setq helm-split-window-preferred-function 'ignore)
+(push '("^\*helm .+\*$" :regexp t) popwin:special-display-config)
+(push '("^\*helm-.+\*$" :regexp t) popwin:special-display-config)
 
 
 ;; Alchemist Settings
-(require 'alchemist)
-(setq alchemist-mix-env "prod")
-
-(setq alchemist-goto-elixir-source-dir "/Users/wpcarro/source_code/elixir")
-(setq alchemist-goto-erlang-source-dir "/Users/wpcarro/source_code/otp/")
+(use-package alchemist
+  :ensure t
+  :config
+  (setq alchemist-mix-env "prod")
+  (setq alchemist-goto-elixir-source-dir "/Users/wpcarro/source_code/elixir")
+  (setq alchemist-goto-erlang-source-dir "/Users/wpcarro/source_code/otp/")
+  :init
+  (linum-mode))
 
-;; Borrow keybinding from list-mode eval
-(define-key global-map (kbd "C-j") nil)
-(define-key alchemist-mode-keymap (kbd "C-j") 'alchemist-eval-current-line)
-
-;; Allow Elixir -> Erlang -> Elixir definition jumping
 (defun custom-erlang-mode-hook ()
+  "Jump to and from Elixir, Erlang, Elixir files."
+
   (define-key erlang-mode-map (kbd "M-,") 'alchemist-goto-jump-back))
 
 (add-hook 'erlang-mode-hook 'custom-erlang-mode-hook)
 
-;; Run tests on file writes
-;; (setq alchemist-hooks-test-on-save t)
-
-
-;; Evil Settings
-(require 'evil)
-(require 'evil-leader)
-
-(defun register-evil-keybindings-for-neotree ()
-  "Registers keybindings for Evil mode for NeoTree plugin."
-  (evil-define-key 'normal neotree-mode-map (kbd "TAB") 'neotree-enter)
-  (evil-define-key 'normal neotree-mode-map (kbd "SPC") 'neotree-enter)
-  (evil-define-key 'normal neotree-mode-map (kbd "q") 'neotree-hide)
-  (evil-define-key 'normal neotree-mode-map (kbd "RET") 'neotree-enter))
-
-;; Evil colored-cursors
-(setq evil-emacs-state-cursor '("red" box))
-(setq evil-normal-state-cursor '("green" box))
-(setq evil-visual-state-cursor '("orange" box))
-(setq evil-insert-state-cursor '("red" bar))
-(setq evil-replace-state-cursor '("red" bar))
-(setq evil-operator-state-cursor '("red" hollow))
-
-
-;; Display column number alongside row number
-(column-number-mode t)
 
 ;; NeoTree Settings
-(require 'neotree)
+(use-package neotree
+  :ensure t
+  :bind (:map neotree-mode-map
+         ("j" . next-line)
+         ("k" . previous-line)
+
+         ("<return>" . neotree-enter)
+         ("<tab>" . neotree-enter)
+
+         ("C-h" . evil-window-left)
+         ("C-l" . evil-window-right)
+         ("C-k" . evil-window-up)
+         ("C-j" . evil-window-down))
+  :init
+  (hl-line-mode))
 
 (defun neotree-project-dir ()
   "Open NeoTree using the git root."
+
   (interactive)
   (let ((project-dir (projectile-project-root))
         (file-name (buffer-file-name)))
@@ -250,27 +245,90 @@
               (neotree-find file-name)))
       (message "Could not find git project root."))))
 
-(global-set-key (kbd "<f8>") 'neotree-project-dir)
 
-(add-hook 'neotree-mode-hook (lambda () (bootstrap-evil-mode) (hl-line-mode)) )
+;; Whitespace Settings
+(use-package whitespace
+  :ensure t
+  :commands (whitespace-mode)
+  :config
+  (setq whitespace-line-column 80)
+  (setq whitespace-style '(face lines-tail)))
 
 
-;; Evil Plugins
+;; Helm Settings
+(use-package helm
+  :ensure t
+  :commands (helm-mode)
+  :bind (
+         ("M-x" . helm-M-x)
+         ("M-y" . helm-show-kill-ring)
+         ("C-x b" . helm-mini)
+         :map helm-map
+         ("TAB" . helm-execute-persistent-action)
+         ("C-z" . helm-select-action)
+
+         :term-raw-map
+         ("M-x" . helm-M-x))
+  :init
+  (setq helm-buffers-fuzzy-matching t)
+  (setq helm-recentf-fuzzy-match t)
+  (setq helm-semantic-fuzzy-match t)
+  (setq helm-imenu-fuzzy-match t)
+  (setq helm-locate-fuzzy-match t))
+
+
+;; Helm Projectile Settings
+(use-package helm-projectile
+  :ensure t
+  :bind ("C-x C-f" . helm-projectile)
+  :init
+  (bind-key "C-x p" 'helm-projectile-ag))
+
+
+;; Company Settings
+(use-package company
+  :config
+  (setq company-idle-delay 0))
+
+
+(add-hook 'after-init-hook 'evil-mode)
+(add-hook 'after-init-hook 'global-whitespace-mode)
+(add-hook 'after-init-hook 'global-hl-line-mode)
+(add-hook 'after-init-hook 'global-linum-mode)
+(add-hook 'after-init-hook 'global-flycheck-mode)
+(add-hook 'after-init-hook 'global-company-mode)
+(add-hook 'after-init-hook 'projectile-mode)
+(add-hook 'after-init-hook 'helm-mode)
+(add-hook 'before-save-hook 'delete-trailing-whitespace)
 
-;; Evil Match-it
-(require 'evil-matchit)
-(global-evil-matchit-mode 1)
 
-;; Evil Surround
-(require 'evil-surround)
-(global-evil-surround-mode 1)
+;; Scrolling Settings
+(setq scroll-step 1)
+(setq scroll-conservatively 10000)
+
+
+;; Properly configure GUI Emacs to use $PATH values
+(when (memq window-system '(mac ns))
+  (exec-path-from-shell-initialize))
+
 
+;; Emacs backup / autosave files
+;; (setq-default make-backup-files nil)
+(setq backup-directory-alist `(("." . "~/.emacs-tmp")))
+(setq auto-save-file-name-transforms `((".*" "~/.emacs-tmp/" t)))
 
-;; Window movement
-(global-set-key (kbd "C-c w f") 'windmove-right)
-(global-set-key (kbd "C-c w b") 'windmove-left)
-(global-set-key (kbd "C-c w p") 'windmove-up)
-(global-set-key (kbd "C-c w n") 'windmove-down)
+
+;; Automatically follow symlinks
+(setq vc-follow-symlinks t)
+
+
+;; Commenting / Uncommenting
+(global-set-key (kbd "C-x C-;") 'comment-or-uncomment-region)
+
+
+;; Fullscreen settings
+(setq ns-use-native-fullscreen nil)
+(global-set-key (kbd "<s-return>") 'toggle-frame-fullscreen)
 
 
 ;; General Settings
@@ -290,63 +348,48 @@
 (set-frame-font "Operator Mono 10")
 
 
-;; Personalized Evil-mode settings
-(defun bootstrap-evil-mode()
-  "Custom evil-mode settings. This disables Emacs key-bindings found in
-`global-map` when inside Vim's `normal` mode. It disables Vim key-bindings
-when in Vim's `insert` mode, favoring native Emacs bindings instead."
+;; Force save buffers
+(defun save-buffer-always ()
+  "Save the buffer even if it is not modified."
   (interactive)
-  (evil-local-mode t)
-
-  ;; Evil-leader
-  (global-evil-leader-mode)
-  (evil-leader/set-leader (kbd "SPC"))
-
-  ;; Toggle off Emacs bindings when in Vim `normal` mode except:
-  ;;   * `M-x`
-  ;; (setcdr global-map nil)
-  ;; (define-key global-map (kbd "M-x") 'helm-M-x)
-
-  (define-key evil-normal-state-map (kbd "") nil)
+  (set-buffer-modified-p t)
+  (save-buffer))
 
-  ;; unbind <SPC> and <CR> in normal mode since they're hardly used
-  (define-key evil-motion-state-map (kbd "RET") nil)
-  (define-key evil-motion-state-map (kbd "SPC") nil)
-  (define-key evil-normal-state-map (kbd "M-.") nil)
+(global-set-key (kbd "C-x C-s") nil)
+(global-set-key (kbd "C-x C-s") 'save-buffer-always)
 
-  ;; use 'helm-swoop for interactive search
-  (define-key evil-motion-state-map (kbd "/") 'helm-swoop)
-  (define-key evil-motion-state-map (kbd "?") 'helm-swoop)
-
-  (define-key evil-normal-state-map (kbd "C-h") 'evil-window-left)
-  (define-key evil-normal-state-map (kbd "C-l") 'evil-window-right)
-  (define-key evil-normal-state-map (kbd "C-k") 'evil-window-up)
-  (define-key evil-normal-state-map (kbd "C-j") 'evil-window-down)
-
-  (define-key evil-normal-state-map (kbd "M-l") (lambda () (interactive) (evil-window-vsplit) (evil-window-right 1) ))
-  (define-key evil-normal-state-map (kbd "M-h") (lambda () (interactive) (evil-window-vsplit) ))
-  (define-key evil-normal-state-map (kbd "M-j") (lambda () (interactive) (evil-window-split) (evil-window-down 1) ))
-  (define-key evil-normal-state-map (kbd "M-k") (lambda () (interactive) (evil-window-split) ))
-
-  ;; Plugin-specific keybindings
-  (register-evil-keybindings-for-neotree)
-
-  ;; Toggle off Vim bindings when in Vim `insert` mode except:
-  ;;   * `<escape>` <ESC>
-  ;;   * `j k` <ESC>
-  ;;   * `j j` "j"
-  (setcdr evil-insert-state-map nil)
-  (define-key evil-insert-state-map (kbd "<escape>") 'evil-force-normal-state)
-  (define-key evil-insert-state-map (kbd "j k") 'evil-force-normal-state)
-  (define-key evil-insert-state-map (kbd "jj") (lambda () (interactive) (insert "j")))
-
-  (define-key evil-normal-state-map (kbd "H") 'evil-first-non-blank)
-  (define-key evil-normal-state-map (kbd "L") 'evil-end-of-line))
 
+;; Upgrade all packages
+(defun package-upgrade-all ()
+  "Upgrade all packages automatically without showing *Packages* buffer."
+  (interactive)
+  (package-refresh-contents)
+  (let (upgrades)
+    (cl-flet ((get-version (name where)
+                (let ((pkg (cadr (assq name where))))
+                  (when pkg
+                    (package-desc-version pkg)))))
+      (dolist (package (mapcar #'car package-alist))
+        (let ((in-archive (get-version package package-archive-contents)))
+          (when (and in-archive
+                     (version-list-< (get-version package package-alist)
+                                     in-archive))
+            (push (cadr (assq package package-archive-contents))
+                  upgrades)))))
+    (if upgrades
+        (when (yes-or-no-p
+               (message "Upgrade %d package%s (%s)? "
+                        (length upgrades)
+                        (if (= (length upgrades) 1) "" "s")
+                        (mapconcat #'package-desc-full-name upgrades ", ")))
+          (save-window-excursion
+            (dolist (package-desc upgrades)
+              (let ((old-package (cadr (assq (package-desc-name package-desc)
+                                             package-alist))))
+                (package-install package-desc)
+                (package-delete  old-package)))))
+      (message "All packages are up to date"))))
 
-;; Line Numbers in margin for source code mode
-(add-hook 'prog-mode-hook 'linum-mode)
-(add-hook 'prog-mode-hook 'bootstrap-evil-mode)
 
 ;; Add transparency
 (set-frame-parameter (selected-frame) 'alpha '(95 . 95))