emacs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410
  1. ;; TODO:
  2. ;; Easier undo tree traversal
  3. ;; Test easing spelling navigation, map ]s and [s to next and previously wrong word
  4. ;; Replace evil-leader with general
  5. ;;;; Startup
  6. (setq initial-scratch-message "")
  7. ;;;; Base
  8. ;; Disable beep & flash
  9. (setq ring-bell-function 'ignore)
  10. ;; Disable blinking cursor
  11. (blink-cursor-mode 0)
  12. ;; TODO finish fixing eval-last-s-exp
  13. ;;(defun evil-eval-prev-exp ()
  14. ;;(interactive)
  15. ;;(evil-append 1)
  16. ;;(call-interactively (global-key-binding "\C-x"))
  17. ;;(call-interactively (global-key-binding "\C-e"))
  18. ;;(evil-normal-state))
  19. ;; All yes or no prompts are y or n
  20. (defalias 'yes-or-no-p 'y-or-n-p)
  21. ;; Never follow symlinks
  22. (setq vc-follow-symlinks nil)
  23. ;;; Leave the OS clipboard alone (use evil's "+ and "* instead)
  24. ; Don't copy and paste to the clipboard
  25. (setq select-enable-clipboard nil)
  26. ; Don't save to the clipboard on exit
  27. (setq x-select-enable-clipboard-manager nil)
  28. ;; Text and Notes
  29. (setq sentence-end-double-space nil)
  30. ;; Save minibar history
  31. (savehist-mode 1)
  32. (setq savehist-additional-variables '(kill-ring search-ring regexp-search-ring))
  33. ;; Auto-enable elisp when opening .emacs in dotfiles (without the .)
  34. (add-to-list 'auto-mode-alist '("emacs" . emacs-lisp-mode))
  35. ;; Start in text-mode
  36. (setq initial-major-mode 'text-mode)
  37. ;; Backups (from https://stackoverflow.com/questions/151945/how-do-i-control-how-emacs-makes-backup-files/20824625#20824625)
  38. (setq version-control t ;; Use version numbers for backups.
  39. kept-new-versions 10 ;; Number of newest versions to keep.
  40. kept-old-versions 0 ;; Number of oldest versions to keep.
  41. delete-old-versions t ;; Don't ask to delete excess backup versions.
  42. backup-by-copying t) ;; Copy all files, don't rename them.
  43. (setq vc-make-backup-files t) ;; Backup versioned files
  44. ;; Default and per-save backups go here:
  45. (setq backup-directory-alist '(("" . "~/.emacs.d/backups/per-save")))
  46. (defun force-backup-of-buffer ()
  47. ;; Make a special "per session" backup at the first save of each
  48. ;; emacs session.
  49. (when (not buffer-backed-up)
  50. ;; Override the default parameters for per-session backups.
  51. (let ((backup-directory-alist '(("" . "~/.emacs.d/backup/per-session")))
  52. (kept-new-versions 3))
  53. (backup-buffer)))
  54. ;; Make a "per save" backup on each save. The first save results in
  55. ;; both a per-session and a per-save backup, to keep the numbering
  56. ;; of per-save backups consistent.
  57. (let ((buffer-backed-up nil))
  58. (backup-buffer)))
  59. (add-hook 'before-save-hook 'force-backup-of-buffer)
  60. ;; Disable toolbar
  61. (when (display-graphic-p)
  62. (tool-bar-mode -1)
  63. )
  64. ;;;; Packages
  65. ;; Package installation
  66. (require 'package)
  67. (add-to-list 'package-archives '("org" . "http://orgmode.org/elpa/"))
  68. (add-to-list 'package-archives '("melpa" . "http://melpa.org/packages/"))
  69. (add-to-list 'package-archives '("melpa-stable" . "http://stable.melpa.org/packages/"))
  70. (setq package-enable-at-startup nil)
  71. (package-initialize)
  72. ;; Function to ensure every package in installed, and ask if it isn't.
  73. (defun ensure-package-installed (&rest packages)
  74. (mapcar
  75. (lambda (package)
  76. (if (package-installed-p package)
  77. nil
  78. (if (y-or-n-p (format "Package %s is missing. Install it? " package))
  79. (package-install package)
  80. package)))
  81. packages))
  82. ;; Make sure to have downloaded archive description.
  83. (or (file-exists-p package-user-dir)
  84. (package-refresh-contents))
  85. ;; List of packages to install on all systems
  86. (setq required-packages
  87. '(
  88. iedit
  89. magit
  90. evil-magit
  91. undo-tree
  92. evil
  93. evil-leader
  94. evil-tabs
  95. powerline-evil
  96. monokai-theme
  97. auto-complete
  98. linum-relative
  99. multi-term
  100. neotree
  101. evil-numbers
  102. editorconfig
  103. ))
  104. ;; List of optional packages
  105. (setq optional-packages
  106. '(
  107. flymd
  108. markdown-mode
  109. latex-preview-pane
  110. tide
  111. web-mode
  112. ac-html
  113. racket-mode
  114. geiser
  115. fuzzy
  116. general))
  117. ;; Update package contents
  118. (when (not package-archive-contents)
  119. (package-refresh-contents))
  120. ;; Check that all packages are installed
  121. (apply 'ensure-package-installed required-packages)
  122. ;; Declare function for optional packages
  123. (defun optional-packages-install ()
  124. (interactive)
  125. (apply 'ensure-package-installed optional-packages))
  126. ;; Activate installed packages
  127. (package-initialize)
  128. ;;; Evil
  129. ;; No C-i jump
  130. (setq evil-want-C-i-jump nil)
  131. ;; Evil tabs
  132. (global-evil-tabs-mode t)
  133. ;; Default to evil mode
  134. (evil-mode t)
  135. ;; Move all elements of evil-emacs-state-modes to evil-motion-state-modes
  136. (setq evil-motion-state-modes (append evil-emacs-state-modes evil-motion-state-modes))
  137. (setq evil-emacs-state-modes nil)
  138. ;; Delete info bindings for evil to take over
  139. (define-key Info-mode-map "g" nil)
  140. (define-key Info-mode-map "n" nil)
  141. (define-key Info-mode-map "p" nil)
  142. ;; Vim removing of windows
  143. (define-key evil-window-map (kbd "q") 'delete-window)
  144. (define-key evil-window-map (kbd "C-q") 'delete-window)
  145. ;; Increment and decrement (evil-numbers)
  146. (define-key evil-insert-state-map (kbd "C-a") 'evil-numbers/inc-at-pt)
  147. (define-key evil-insert-state-map (kbd "C-d") 'evil-numbers/dec-at-pt)
  148. ;;; undo-tree
  149. ;; Save undo history under .emacs.d/undo
  150. (setq undo-tree-auto-save-history t
  151. undo-tree-history-directory-alist
  152. `(("." . ,(concat user-emacs-directory "undo"))))
  153. (unless (file-exists-p (concat user-emacs-directory "undo"))
  154. (make-directory (concat user-emacs-directory "undo")))
  155. ;;; Powerline
  156. (require 'powerline)
  157. (powerline-evil-center-color-theme)
  158. ;;; Recent Files
  159. (require 'recentf)
  160. (recentf-mode 1)
  161. (setq recentf-max-saved-items 200
  162. recentf-max-menu-items 15)
  163. ;;; Web mode
  164. (require 'web-mode)
  165. ;; 2 spaces for an indent
  166. (defun my-web-mode-hook ()
  167. "Hooks for Web mode."
  168. (setq web-mode-markup-indent-offset 2)
  169. )
  170. (add-hook 'web-mode-hook 'my-web-mode-hook)
  171. ;; Auto-enable web-mode when opening relevent files
  172. (add-to-list 'auto-mode-alist '("\\.html\\'" . web-mode))
  173. (add-to-list 'auto-mode-alist '("\\.hbs\\'" . web-mode))
  174. (add-to-list 'auto-mode-alist '("\\.handlebars\\'" . web-mode))
  175. ;;; Autocomplete
  176. (require 'auto-complete)
  177. ;; start auto-complete
  178. (eval-and-compile
  179. (require 'auto-complete nil 'noerror))
  180. (ac-config-default)
  181. (setq ac-auto-start t)
  182. (global-set-key (kbd "<backtab>") 'ac-previous)
  183. (require 'ac-html)
  184. (setq web-mode-ac-sources-alist
  185. '(("css" . (ac-source-css-property))
  186. ("html" . (ac-source-words-in-buffer ac-source-abbrev))))
  187. (ac-linum-workaround)
  188. (setq ac-auto-show-menu t)
  189. ;;; Spelling
  190. ;; map ]s and [s to next and previously wrong word
  191. ;; move point to previous error
  192. ;; based on code by hatschipuh at
  193. ;; http://emacs.stackexchange.com/a/14912/2017
  194. (defun flyspell-goto-previous-error (arg)
  195. "Go to arg previous spelling error."
  196. (interactive "p")
  197. (while (not (= 0 arg))
  198. (let ((pos (point))
  199. (min (point-min)))
  200. (if (and (eq (current-buffer) flyspell-old-buffer-error)
  201. (eq pos flyspell-old-pos-error))
  202. (progn
  203. (if (= flyspell-old-pos-error min)
  204. ;; goto beginning of buffer
  205. (progn
  206. (message "Restarting from end of buffer")
  207. (goto-char (point-max)))
  208. (backward-word 1))
  209. (setq pos (point))))
  210. ;; seek the next error
  211. (while (and (> pos min)
  212. (let ((ovs (overlays-at pos))
  213. (r '()))
  214. (while (and (not r) (consp ovs))
  215. (if (flyspell-overlay-p (car ovs))
  216. (setq r t)
  217. (setq ovs (cdr ovs))))
  218. (not r)))
  219. (backward-word 1)
  220. (setq pos (point)))
  221. ;; save the current location for next invocation
  222. (setq arg (1- arg))
  223. (setq flyspell-old-pos-error pos)
  224. (setq flyspell-old-buffer-error (current-buffer))
  225. (goto-char pos)
  226. (if (= pos min)
  227. (progn
  228. (message "No more miss-spelled word!")
  229. (setq arg 0))
  230. (forward-word)))))
  231. (global-set-key (kbd "C-=") 'flyspell-goto-next-error)
  232. (global-set-key (kbd "M-=") 'flyspell-goto-previous-error)
  233. ;;; Relative line numbers
  234. (require 'linum-relative)
  235. (setq linum-relative-current-symbol "")
  236. (linum-mode)
  237. (linum-relative-global-mode)
  238. ;;; flymd
  239. ; flymd.md and flymd.html are deleted upon markdown buffer killed
  240. (setq flymd-close-buffer-delete-temp-files t)
  241. ;;; evil-leader
  242. ;; Evil leader is Space
  243. (global-evil-leader-mode)
  244. (evil-leader/set-leader "<SPC>")
  245. ;; Leader keybinds
  246. (evil-leader/set-key
  247. "d" 'diff-buffer-with-file
  248. "b" 'buffer-menu
  249. ;"f" '(lambda () (interactive) (dired '"./"))
  250. "f" 'neotree-toggle
  251. "u" 'undo-tree-visualize
  252. "m" 'recentf-open-files
  253. "l" 'auto-fill-mode
  254. "s" '(lambda () (interactive) (if flyspell-mode (funcall 'flyspell-mode '0) (flyspell-mode) (flyspell-buffer)))
  255. "a" 'auto-complete-mode
  256. "g" 'magit-status
  257. "M-g" 'magit-dispatch-popup
  258. )
  259. ;; Magit
  260. (require 'magit)
  261. (setq evil-magit-state 'normal)
  262. (require 'evil-magit)
  263. (global-magit-file-mode)
  264. ;; Neotree
  265. ; Set vi-like bindings in neotree-mode that don't conflict with evil
  266. (evil-define-key 'normal neotree-mode-map (kbd "TAB") 'neotree-enter)
  267. (evil-define-key 'normal neotree-mode-map (kbd "SPC") 'neotree-enter)
  268. (evil-define-key 'normal neotree-mode-map (kbd "q") 'neotree-hide)
  269. (evil-define-key 'normal neotree-mode-map (kbd "RET") 'neotree-enter)
  270. (evil-define-key 'normal neotree-mode-map (kbd "h") 'neotree-hidden-file-toggle)
  271. ;Every time when the neotree window is opened, let it find current file and jump to node.
  272. (setq neo-smart-open t)
  273. ;; tide/typescript
  274. (setq typescript-indent-level 2)
  275. ;; JavaScript
  276. (setq js-indent-level 2)
  277. ;; geiser
  278. (add-to-list 'auto-mode-alist '("\\.scm\\'" . scheme-mode))
  279. ;; editorconfig
  280. (editorconfig-mode 1)
  281. ;;;; System-specific configs
  282. (defun win-setup ()
  283. (add-to-list 'exec-path "C:/Program Files (x86)/Aspell/bin/")
  284. (setq ispell-program-name "aspell")
  285. (defun cmd ()
  286. (interactive)
  287. (make-comint-in-buffer "cmd" nil "cmd" nil)
  288. (switch-to-buffer "*cmd*")))
  289. (defun linux-setup ())
  290. (cond ((eq system-type 'windows-nt) (win-setup))
  291. ((eq system-type 'gnu/linux) (linux-setup))
  292. (t (message "")))
  293. ;;;; Custom
  294. (defconst custom-file (expand-file-name "custom.el" user-emacs-directory))
  295. ;; if no custom file exists, write a default one
  296. (unless (file-exists-p custom-file)
  297. (write-region "(custom-set-faces
  298. ;; custom-set-faces was added by Custom.
  299. ;; If you edit it by hand, you could mess it up, so be careful.
  300. ;; Your init file should contain only one such instance.
  301. ;; If there is more than one, they won't work right.
  302. '(powerline-evil-normal-face ((t (:background \"#859900\")))))
  303. (custom-set-variables
  304. ;; custom-set-variables was added by Custom.
  305. ;; If you edit it by hand, you could mess it up, so be careful.
  306. ;; Your init file should contain only one such instance.
  307. ;; If there is more than one, they won't work right.
  308. '(custom-enabled-themes (quote (monokai)))
  309. '(custom-safe-themes
  310. (quote
  311. (\"c7a9a68bd07e38620a5508fef62ec079d274475c8f92d75ed0c33c45fbe306bc\" default))))
  312. " nil custom-file))
  313. (load custom-file)