blob: 50e26d3c3c8d0be1f8b298be476ee69df6ad4fb8 (
plain) (
blame)
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
|
;;; init-clojure.el --- Clojure Configuration File -*- lexical-binding: t -*-
;;; Commentary:
;;; Code:
;(require 'init-lisp)
(use-package yasnippet
:diminish yas-minor-mode)
(use-package flycheck-clj-kondo)
(use-package clojure-mode
:config
(require 'flycheck-clj-kondo)
(subword-mode +1)
(define-abbrev-table 'clojure-mode-abbrev-table
'(("scs" "#sc/spy")
("scp" "#spy/p")
("scd" "#spy/d")
("sct" "#spy/t")
("ms" "(miracle.save/save)" backward-char)
("ddb" "#d/dbg")
("dbn" "#d/dbgn")))
;; https://github.com/weavejester/compojure/wiki/Emacs-indentation
(define-clojure-indent
(defroutes 'defun)
(GET 2)
(POST 2)
(PUT 2)
(DELETE 2)
(HEAD 2)
(ANY 2)
(OPTIONS 2)
(PATCH 2)
(rfn 2)
(let-routes 1)
(context 2))
:init
;; Always show more of the path in clj buffer names.
;; Using setq-local in clojure-mode-hook is not enough, as it runs too late
(defun clj-uniquify-get-proposed-name (orig base dirname &optional depth original-dirname)
(when (and (> (length base) 4)
(string= ".clj" (substring base -4))
(not (string= "project.clj" base)))
(setq-local uniquify-min-dir-content 3))
(funcall orig base dirname depth original-dirname))
(advice-add 'uniquify-get-proposed-name :around 'clj-uniquify-get-proposed-name))
(use-package clj-refactor
:diminish
:bind ("C-c @" . hydra-cljr-help-menu/body)
:custom
(cljr-suppress-no-project-warning t)
(cljr-add-ns-to-blank-clj-files nil) ; disable clj-refactor adding ns to blank files
:config
(cljr-add-keybindings-with-prefix "C-c C-m")
(defun clj-refactor-hook-fn ()
(clj-refactor-mode 1)
(yas-minor-mode 1))
:hook
(clojure-mode . clj-refactor-hook-fn))
(use-package cider
:diminish
:config
(defvar cider-main-function "-main")
(defun cider-repl-mode-hook-fn ()
(display-line-numbers-mode -1)
(subword-mode +1))
(defun run-and-unhook ()
(remove-hook 'cider-connected-hook 'run-and-unhook)
(run-main))
(defun run-main ()
(interactive)
(cider-insert-in-repl (concat "(" cider-main-function ")") t))
(defun cider-jack-in-and-run-main (arg &rest params)
(interactive "P")
(if (equal current-prefix-arg '(4))
(progn
(add-hook 'cider-connected-hook 'run-and-unhook)
(cider-jack-in params))
(cider-jack-in params)))
(define-abbrev-table 'cider-repl-mode-abbrev-table
'(("scl" "(eval `(sc.api/defsc ~(sc.api/last-ep-id)))" cider-repl-return)
("scs" "(sc.api/defsc*)" cider-repl-return)
("scd" "(sc.api/defsc)" backward-char)
("ms" "(use 'miracle.save)" cider-repl-return)
("ld" "(ld)" backward-char)
("ps" "(print-saves)" backward-char)
("sv" "(save-var*)" backward-char)
("usv" "(unsave-var*)" backward-char)
("sn" "(save-ns*)" backward-char)
("usn" "(unsave-ns*)" backward-char)
("fs" "@f-saves")
("ldf" "(ld)" backward-char)
("pfs" "(print-f-saves)" backward-char)
("scr" "(use 'spyscope.repl)" cider-repl-return)))
(setq cider-repl-pop-to-buffer-on-connect 'display-only
cider-repl-display-help-banner nil
cider-repl-history-highlight-current-entry t
cider-repl-history-highlight-inserted-item t
cider-repl-use-clojure-font-lock t
cider-repl-use-pretty-printing t
cider-save-file-on-load t
cider-test-show-report-on-success t
;; cider-invert-insert-eval-p t
;; cider-switch-to-repl-on-insert nil
cider-xref-fn-depth 90
cider-repl-history-file ".cider-repl-history"
nrepl-log-messages t
cider-connection-message-fn nil
cider-show-error-buffer 'except-in-repl
clojure-toplevel-inside-comment-form t)
(unbind-key "C-c C-l" cider-mode-map)
(unbind-key "C-c C-b" cider-mode-map)
(unbind-key "C-c C-b" cider-repl-mode-map)
:bind
(:map cider-mode-map
("C-c M-l" . cider-load-file)
("C-c M-b" . cider-interrupt))
(:map cider-repl-mode-map
("C-c M-b" . cider-interrupt))
(:map cider-start-map
("C-c M-j" . cider-jack-in-and-run-main))
(:map clojure-mode-map
("C-c C-r C-m" . run-main)
("C-c M-j" . cider-jack-in-and-run-main)
("C-x p q" . project-clojure-test-switch)
("C-c C-M-c" . (lambda () (interactive) (cider-clear-compilation-highlights t)))
("C-c C->" . cider-find-dwim)
("C-x 4 C->" . cider-find-dwim-other-window))
:hook
(cider-repl-mode . cider-repl-mode-hook-fn)
(cider-mode . eldoc-mode))
(provide 'init-clojure)
;;; init-clojure.el ends here
|