git.el: Preserve file marks when doing a full refresh.
Signed-off-by: Alexandre Julliard <julliard@winehq.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
fe50eef59b
commit
b9b7bab4b6
@ -494,24 +494,31 @@ and returns the process output as a string."
|
|||||||
(setf (git-fileinfo->orig-name info) nil)
|
(setf (git-fileinfo->orig-name info) nil)
|
||||||
(setf (git-fileinfo->needs-refresh info) t))))
|
(setf (git-fileinfo->needs-refresh info) t))))
|
||||||
|
|
||||||
(defun git-set-filenames-state (status files state)
|
(defun git-status-filenames-map (status func files &rest args)
|
||||||
"Set the state of a list of named files."
|
"Apply FUNC to the status files names in the FILES list."
|
||||||
(when files
|
(when files
|
||||||
(setq files (sort files #'string-lessp))
|
(setq files (sort files #'string-lessp))
|
||||||
(let ((file (pop files))
|
(let ((file (pop files))
|
||||||
(node (ewoc-nth status 0)))
|
(node (ewoc-nth status 0)))
|
||||||
(while (and file node)
|
(while (and file node)
|
||||||
(let ((info (ewoc-data node)))
|
(let ((info (ewoc-data node)))
|
||||||
(cond ((string-lessp (git-fileinfo->name info) file)
|
(if (string-lessp (git-fileinfo->name info) file)
|
||||||
(setq node (ewoc-next status node)))
|
(setq node (ewoc-next status node))
|
||||||
((string-equal (git-fileinfo->name info) file)
|
(if (string-equal (git-fileinfo->name info) file)
|
||||||
|
(apply func info args))
|
||||||
|
(setq file (pop files))))))))
|
||||||
|
|
||||||
|
(defun git-set-filenames-state (status files state)
|
||||||
|
"Set the state of a list of named files."
|
||||||
|
(when files
|
||||||
|
(git-status-filenames-map status
|
||||||
|
(lambda (info state)
|
||||||
(unless (eq (git-fileinfo->state info) state)
|
(unless (eq (git-fileinfo->state info) state)
|
||||||
(setf (git-fileinfo->state info) state)
|
(setf (git-fileinfo->state info) state)
|
||||||
(setf (git-fileinfo->rename-state info) nil)
|
(setf (git-fileinfo->rename-state info) nil)
|
||||||
(setf (git-fileinfo->orig-name info) nil)
|
(setf (git-fileinfo->orig-name info) nil)
|
||||||
(setf (git-fileinfo->needs-refresh info) t))
|
(setf (git-fileinfo->needs-refresh info) t)))
|
||||||
(setq file (pop files)))
|
files state)
|
||||||
(t (setq file (pop files)))))))
|
|
||||||
(unless state ;; delete files whose state has been set to nil
|
(unless state ;; delete files whose state has been set to nil
|
||||||
(ewoc-filter status (lambda (info) (git-fileinfo->state info))))))
|
(ewoc-filter status (lambda (info) (git-fileinfo->state info))))))
|
||||||
|
|
||||||
@ -1197,11 +1204,20 @@ Return the list of files that haven't been handled."
|
|||||||
(interactive)
|
(interactive)
|
||||||
(let* ((status git-status)
|
(let* ((status git-status)
|
||||||
(pos (ewoc-locate status))
|
(pos (ewoc-locate status))
|
||||||
|
(marked-files (git-get-filenames (ewoc-collect status (lambda (info) (git-fileinfo->marked info)))))
|
||||||
(cur-name (and pos (git-fileinfo->name (ewoc-data pos)))))
|
(cur-name (and pos (git-fileinfo->name (ewoc-data pos)))))
|
||||||
(unless status (error "Not in git-status buffer."))
|
(unless status (error "Not in git-status buffer."))
|
||||||
(git-run-command nil nil "update-index" "--refresh")
|
(git-run-command nil nil "update-index" "--refresh")
|
||||||
(git-clear-status status)
|
(git-clear-status status)
|
||||||
(git-update-status-files nil)
|
(git-update-status-files nil)
|
||||||
|
; restore file marks
|
||||||
|
(when marked-files
|
||||||
|
(git-status-filenames-map status
|
||||||
|
(lambda (info)
|
||||||
|
(setf (git-fileinfo->marked info) t)
|
||||||
|
(setf (git-fileinfo->needs-refresh info) t))
|
||||||
|
marked-files)
|
||||||
|
(git-refresh-files))
|
||||||
; move point to the current file name if any
|
; move point to the current file name if any
|
||||||
(let ((node (and cur-name (git-find-status-file status cur-name))))
|
(let ((node (and cur-name (git-find-status-file status cur-name))))
|
||||||
(when node (ewoc-goto-node status node)))))
|
(when node (ewoc-goto-node status node)))))
|
||||||
|
Loading…
Reference in New Issue
Block a user