diff options
author | Franck Cuny <franck@fcuny.net> | 2022-03-23 19:43:46 -0700 |
---|---|---|
committer | Franck Cuny <franck@fcuny.net> | 2022-03-23 19:43:46 -0700 |
commit | d52fb88582f431738994a3321614bd7ec76e7f56 (patch) | |
tree | ca3dfc64107cb9e06e47c4edcd69f4d79a63bde3 /emacs/elisp/my-buffers.el | |
parent | functions: move custom functions to libraries (diff) | |
download | emacs.d-d52fb88582f431738994a3321614bd7ec76e7f56.tar.gz |
this should be the last mass refactor
Diffstat (limited to '')
-rw-r--r-- | emacs/elisp/my-buffers.el | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/emacs/elisp/my-buffers.el b/emacs/elisp/my-buffers.el index d5c07c5..8c03905 100644 --- a/emacs/elisp/my-buffers.el +++ b/emacs/elisp/my-buffers.el @@ -9,5 +9,31 @@ (mark-whole-buffer) (copy-region-as-kill 1 (buffer-size)))) +(defun my/rename-this-buffer-and-file () + "Renames current buffer and file it is visiting." + (interactive) + (let ((name (buffer-name)) + (filename (buffer-file-name)) + (read-file-name-function 'read-file-name-default)) + (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))) + (cond ((get-buffer new-name) + (error "A buffer named '%s' already exists!" new-name)) + (t + (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)))))))) + +(defun my/uniquify-region-lines (beg end) + "Remove duplicate adjacent lines in region between BEG and END." + (interactive "*r") + (save-excursion + (goto-char beg) + (while (re-search-forward "^\\(.*\n\\)\\1+" end t) + (replace-match "\\1")))) + (provide 'my-buffers) ;;; my-buffers.el ends here |