forked from purcell/emacs.d
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinit-paredit.el
59 lines (44 loc) · 2.31 KB
/
init-paredit.el
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
;;; init-paredit.el --- Configure paredit structured editing -*- lexical-binding: t -*-
;;; Commentary:
;;; Code:
(require-package 'paredit)
(defun sanityinc/maybe-map-paredit-newline ()
(unless (or (derived-mode-p 'inferior-emacs-lisp-mode 'cider-repl-mode)
(minibufferp))
(local-set-key (kbd "RET") 'paredit-newline)))
(add-hook 'paredit-mode-hook 'sanityinc/maybe-map-paredit-newline)
(with-eval-after-load 'paredit
(diminish 'paredit-mode " Par")
;; Suppress certain paredit keybindings to avoid clashes, including
;; my global binding of M-?
(dolist (binding '("RET" "C-<left>" "C-<right>" "C-M-<left>" "C-M-<right>" "M-s" "M-?"))
(define-key paredit-mode-map (read-kbd-macro binding) nil))
(define-key paredit-mode-map (kbd "M-<up>") 'paredit-splice-sexp-killing-backward))
;; Use paredit in the minibuffer
;; TODO: break out into separate package
;; http://emacsredux.com/blog/2013/04/18/evaluate-emacs-lisp-in-the-minibuffer/
(add-hook 'minibuffer-setup-hook 'sanityinc/conditionally-enable-paredit-mode)
(defvar paredit-minibuffer-commands '(eval-expression
pp-eval-expression
eval-expression-with-eldoc
ibuffer-do-eval
ibuffer-do-view-and-eval)
"Interactive commands for which paredit should be enabled in the minibuffer.")
(defun sanityinc/conditionally-enable-paredit-mode ()
"Enable paredit during lisp-related minibuffer commands."
(when (memq this-command paredit-minibuffer-commands)
(enable-paredit-mode)))
(add-hook 'sanityinc/lispy-modes-hook 'enable-paredit-mode)
(when (maybe-require-package 'puni)
;;(add-hook 'prog-mode-hook 'puni-mode)
(add-hook 'sanityinc/lispy-modes-hook (lambda () (puni-mode -1)))
(with-eval-after-load 'puni
(define-key puni-mode-map (kbd "M-(") 'puni-wrap-round)
(define-key puni-mode-map (kbd "C-(") 'puni-slurp-backward)
(define-key puni-mode-map (kbd "C-)") 'puni-slurp-forward)
(define-key puni-mode-map (kbd "C-}") 'puni-barf-forward)
(define-key puni-mode-map (kbd "C-{") 'puni-barf-backward)
(define-key puni-mode-map (kbd "M-<up>") 'puni-splice-killing-backward)
(define-key puni-mode-map (kbd "C-w") nil)))
(provide 'init-paredit)
;;; init-paredit.el ends here