blob: 5c36208709ba57876fc2e13e10bec4209901303f (
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
;; http://whattheemacsd.com/
;; whitespace cleanup
(defun km/cleanup-buffer ()
(interactive)
(unless (equal major-mode 'makefile-gmake-mode)
(untabify (point-min) (point-max)))
(delete-trailing-whitespace)
(set-buffer-file-coding-system 'utf-8))
(add-hook 'before-save-hook 'km/cleanup-buffer)
(defun km/rename-current-buffer-file ()
"Renames current buffer and file it is visiting."
(interactive)
(let ((name (buffer-name))
(filename (buffer-file-name)))
(if (not (and filename (file-exists-p filename)))
(error "Buffer '%s' is not visiting a file!" name)
(let ((new-name (read-file-name "New name: " filename)))
(if (get-buffer new-name)
(error "A buffer named '%s' already exists!" new-name)
(rename-file filename new-name 1)
(rename-buffer new-name)
(set-visited-file-name new-name)
(set-buffer-modified-p nil)
(message "File '%s' successfully renamed to '%s'"
name (file-name-nondirectory new-name)))))))
(global-set-key (kbd "C-x C-r") 'km/rename-current-buffer-file)
(defun km/shebang (&optional lang)
(interactive "s\language (default python):")
(if (= (length lang) 0)
(setq lang "python"))
(insert "#!/usr/bin/env " lang "\n"))
(global-set-key (kbd "C-c s") 'km/shebang)
(defun km/insert-date ()
(interactive)
(insert (format-time-string "%Y-%m-%d")))
(global-set-key (kbd "C-c d") 'km/insert-date)
(defun km/start-ess ()
(interactive)
(require 'ess-site))
;; http://emacs-fu.blogspot.com/2013/03/editing-with-root-privileges-once-more.html
(defun km/find-file-as-root ()
"`ido-find-file` that automatically edits the file with
root-privileges (using tramp/sudo) if the file is not writable by
user."
(interactive)
(let ((file (ido-read-file-name "Edit as root: ")))
(unless (file-writable-p file)
(setq file (concat "/sudo:root@localhost:" file)))
(find-file file)))
(global-set-key (kbd "C-x F") 'km/find-file-as-root)
(defun km/save-and-kill-buffer ()
"Save current buffer and then kill it"
(interactive)
(save-buffer)
(kill-this-buffer))
(defun km/toggle-line-or-region-comment ()
"Comment/uncomment the current line or region"
(interactive)
(let (beg end)
(if (region-active-p)
(setq beg (region-beginning) end (region-end))
(setq beg (line-beginning-position) end (line-end-position)))
(comment-or-uncomment-region beg end))
(forward-line))
;; kill functions
(defun km/kill-string-at-point ()
(interactive)
(let ((string-start (nth 8 (syntax-ppss))))
(goto-char string-start)
(kill-sexp)))
(defun km/kill-thing-at-point (thing killthing killarg)
"Go to the beginning of THING and call KILLTHING with
KILLARG."
(goto-char (beginning-of-thing thing))
(funcall killthing killarg))
(defun km/kill-sentence-at-point (arg)
(interactive "P")
(km/kill-thing-at-point 'sentence 'kill-sentence arg))
(defun km/kill-word-at-point (arg)
(interactive "P")
(km/kill-thing-at-point 'word 'kill-word arg))
(defun km/kill-paragraph-at-point (arg)
(interactive "P")
(km/kill-thing-at-point 'paragraph 'kill-paragraph arg))
(defun km/kill-line-at-point (arg)
(interactive "P")
(km/kill-thing-at-point 'line 'kill-line arg))
(defun km/kill-sexp-at-point (arg)
(interactive "P")
(km/kill-thing-at-point 'sexp 'kill-sexp arg))
(global-set-key (kbd "C-c k s") 'km/kill-string-at-point)
(global-set-key (kbd "C-c k .") 'km/kill-sentence-at-point)
(global-set-key (kbd "C-c k w") 'km/kill-word-at-point)
(global-set-key (kbd "C-c k p") 'km/kill-paragraph-at-point)
(global-set-key (kbd "C-c k l") 'km/kill-line-at-point)
|