add others-utils to git
This commit is contained in:
parent
8bcd2ff68b
commit
ec133bda8a
2
.gitignore
vendored
2
.gitignore
vendored
@ -4,3 +4,5 @@
|
||||
!init.el
|
||||
!my-utils/
|
||||
!my-utils/*
|
||||
!others-utils/
|
||||
!others-utils/*
|
11
others-utils/emacsredux.el
Normal file
11
others-utils/emacsredux.el
Normal file
@ -0,0 +1,11 @@
|
||||
;;; Edit files as root
|
||||
;; https://emacsredux.com/blog/2013/04/21/edit-files-as-root/
|
||||
(defun emacsredux-sudo-edit (&optional arg)
|
||||
"Edit currently visited file as root. With a prefix ARG prompt
|
||||
for a file to visit. Will also prompt for a file to visit if
|
||||
current buffer is not visiting a file."
|
||||
(interactive "P")
|
||||
(if (or arg (not buffer-file-name))
|
||||
(find-file (concat "/sudo:root@localhost:"
|
||||
(read-file-name "Find file(as root): ")))
|
||||
(find-alternate-file (concat "/sudo:root@localhost:" buffer-file-name))))
|
53
others-utils/fuco1.el
Normal file
53
others-utils/fuco1.el
Normal file
@ -0,0 +1,53 @@
|
||||
;;; Enhanced beginning- and end-of-buffer in special mode buffers (dired etc.)
|
||||
;; https://fuco1.github.io/2017-05-06-Enhanced-beginning--and-end-of-buffer-in-special-mode-buffers-(dired-etc.).html
|
||||
|
||||
(defmacro fuco1-special-beginning-of-buffer (mode &rest forms)
|
||||
"Define a special version of `beginning-of-buffer' in MODE.
|
||||
|
||||
The special function is defined such that the point first moves
|
||||
to `point-min' and then FORMS are evaluated. If the point did
|
||||
not change because of the evaluation of FORMS, jump
|
||||
unconditionally to `point-min'. This way repeated invocations
|
||||
toggle between real beginning and logical beginning of the
|
||||
buffer."
|
||||
(declare (indent 1))
|
||||
(let ((fname (intern (concat "my-" (symbol-name mode) "-beginning-of-buffer")))
|
||||
(mode-map (intern (concat (symbol-name mode) "-mode-map")))
|
||||
(mode-hook (intern (concat (symbol-name mode) "-mode-hook"))))
|
||||
`(progn
|
||||
(defun ,fname ()
|
||||
(interactive)
|
||||
(let ((p (point)))
|
||||
(goto-char (point-min))
|
||||
,@forms
|
||||
(when (= p (point))
|
||||
(goto-char (point-min)))))
|
||||
(add-hook ',mode-hook
|
||||
(lambda ()
|
||||
(define-key ,mode-map
|
||||
[remap beginning-of-buffer] ',fname))))))
|
||||
|
||||
(defmacro fuco1-special-end-of-buffer (mode &rest forms)
|
||||
"Define a special version of `end-of-buffer' in MODE.
|
||||
|
||||
The special function is defined such that the point first moves
|
||||
to `point-max' and then FORMS are evaluated. If the point did
|
||||
not change because of the evaluation of FORMS, jump
|
||||
unconditionally to `point-max'. This way repeated invocations
|
||||
toggle between real end and logical end of the buffer."
|
||||
(declare (indent 1))
|
||||
(let ((fname (intern (concat "my-" (symbol-name mode) "-end-of-buffer")))
|
||||
(mode-map (intern (concat (symbol-name mode) "-mode-map")))
|
||||
(mode-hook (intern (concat (symbol-name mode) "-mode-hook"))))
|
||||
`(progn
|
||||
(defun ,fname ()
|
||||
(interactive)
|
||||
(let ((p (point)))
|
||||
(goto-char (point-max))
|
||||
,@forms
|
||||
(when (= p (point))
|
||||
(goto-char (point-max)))))
|
||||
(add-hook ',mode-hook
|
||||
(lambda ()
|
||||
(define-key ,mode-map
|
||||
[remap end-of-buffer] ',fname))))))
|
Loading…
Reference in New Issue
Block a user