1
0
mirror of https://git.savannah.gnu.org/git/emacs.git synced 2024-12-13 09:32:47 +00:00

* lisp/vc/vc-dir.el: Commands to mark un/registered files (bug#34949)

* lisp/vc/vc-dir.el (vc-dir-mark-state-files): New function.
(vc-dir-mark-registered-files)
(vc-dir-mark-unregistered-files): New commands.
(vc-dir-mode-map): Bind vc-dir-mark-registered-files to '* r'.
(vc-dir-menu-map): Add menu entries for
vc-dir-mark-registered-files and vc-dir-mark-unregistered-files.
This commit is contained in:
Juri Linkov 2020-04-03 01:08:09 +03:00
parent bb729496f9
commit adfcc17e6f
2 changed files with 34 additions and 0 deletions

View File

@ -115,6 +115,9 @@ directories with the help of new command 'dired-vc-next-action'.
*** New command 'vc-dir-root' uses the root directory without asking.
*** New commands 'vc-dir-mark-registered-files' (bound to '* r') and
'vc-dir-mark-unregistered-files'.
** Gnus
---

View File

@ -147,6 +147,12 @@ See `run-hooks'."
'(menu-item "Unmark Previous " vc-dir-unmark-file-up
:help "Move to the previous line and unmark the file"))
(define-key map [mark-unregistered]
'(menu-item "Mark Unregistered" vc-dir-mark-unregistered-files
:help "Mark all files in the unregistered state"))
(define-key map [mark-registered]
'(menu-item "Mark Registered" vc-dir-mark-registered-files
:help "Mark all files in the state edited, added or removed"))
(define-key map [mark-all]
'(menu-item "Mark All" vc-dir-mark-all-files
:help "Mark all files that are in the same state as the current file\
@ -310,6 +316,10 @@ See `run-hooks'."
(define-key branch-map "l" 'vc-print-branch-log)
(define-key branch-map "s" 'vc-retrieve-tag))
(let ((mark-map (make-sparse-keymap)))
(define-key map "*" mark-map)
(define-key mark-map "r" 'vc-dir-mark-registered-files))
;; Hook up the menu.
(define-key map [menu-bar vc-dir-mode]
`(menu-item
@ -707,6 +717,27 @@ MARK-FILES should be a list of absolute filenames."
t))
vc-ewoc))
(defun vc-dir-mark-state-files (states)
"Mark files that are in the state specified by the list in STATES."
(unless (listp states)
(setq states (list states)))
(ewoc-map
(lambda (filearg)
(when (memq (vc-dir-fileinfo->state filearg) states)
(setf (vc-dir-fileinfo->marked filearg) t)
t))
vc-ewoc))
(defun vc-dir-mark-registered-files ()
"Mark files that are in one of registered state: edited, added or removed."
(interactive)
(vc-dir-mark-state-files '(edited added removed)))
(defun vc-dir-mark-unregistered-files ()
"Mark files that are in unregistered state."
(interactive)
(vc-dir-mark-state-files 'unregistered))
(defun vc-dir-unmark-file ()
;; Unmark the current file and move to the next line.
(let* ((crt (ewoc-locate vc-ewoc))