blob: 7c3befdbc3c82864b928f8feb8f8e5dcf7bbd92b (
plain)
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
|
(define-prefix-command 'km/external-map)
(global-set-key (kbd "C-c x") 'km/external-map)
;;; Terminals
(defvar km/terminal "urxvt")
(defun km/open-external-terminal ()
(interactive)
(start-process "ext-term" nil km/terminal))
(defadvice shell-command (around shell-command-restore-windows activate)
"Restore window configuraiton after shell-command.
The hides the *Async Shell Command* buffer that is opened in the
other window when an asynchronous command is run."
(window-configuration-to-register :before-shell-command)
ad-do-it
(jump-to-register :before-shell-command))
(defun km/zsh-ansi-term (&optional new-buffer)
"Open an ansi-term buffer running ZSH.
The buffer is named according to `default-directory'. If a buffer
of the same name already exists, switch to it unless NEW-BUFFER
is non-nil."
(interactive "P")
(let ((name (concat "zsh:" (abbreviate-file-name default-directory))))
(-if-let (buffer-name (and (not new-buffer)
(get-buffer (concat "*" name "*"))))
(switch-to-buffer buffer-name)
(ansi-term "/bin/zsh" name))))
(defun km/zsh-ansi-term-other-window (&optional new-buffer)
(interactive "P")
(let (buffer-name)
(save-window-excursion
(setq buffer-name (km/zsh-ansi-term new-buffer)))
(pop-to-buffer buffer-name)))
(define-key km/external-map "a" 'km/zsh-ansi-term)
;; This overrides binding for `add-change-log-entry-other-window'.
(define-key ctl-x-4-map "a" 'km/zsh-ansi-term-other-window)
(define-key km/external-map "t" 'km/open-external-terminal)
(define-key km/external-map "r" 'shell-command-on-region)
(define-key km/external-map "s" 'shell-command)
(define-key km/external-map "S" 'shell)
(define-key km/external-map "w" 'woman)
;;; Compilation
(defadvice compile (around prevent-duplicate-compilation-windows activate)
"Pop to compilation buffer only if it isn't visible.
This is useful for using multiple frames (e.g., with a two
monitor setup)."
(if (get-buffer-window "*compilation*" 'visible)
(save-window-excursion
ad-do-it)
ad-do-it))
(defadvice recompile (around prevent-window-on-compilation activate)
"Prevent recompiling from spawning new windows."
(save-window-excursion
ad-do-it))
(defun km/display-compilation-other-window ()
(interactive)
(-if-let (comp-buffer (get-buffer "*compilation*"))
(display-buffer comp-buffer)
(error "No compilation buffer")))
(define-key km/external-map "c" 'compile)
(define-key km/external-map "g" 'recompile)
(define-key km/external-map "o" 'km/display-compilation-other-window)
;; Give frequently-used recompile a shorter binding.
(global-set-key (kbd "C-c g") 'recompile)
;;; Diff
(setq diff-command "/bin/diff"
diff-switches "-u")
(defadvice diff (after diff-select-and-view activate)
(select-window (get-buffer-window "*Diff*"))
(view-mode 1))
(defun km/revert-buffer-and-view ()
(interactive)
(revert-buffer)
(view-mode 1))
(define-key km/external-map "d" 'diff)
(define-key km/external-map "e" 'ediff)
(after 'diff
(define-key diff-mode-map (kbd "C-c C-g") 'km/revert-buffer-and-view))
(provide 'init-external)
|