]> git.eshelyaron.com Git - emacs.git/commitdiff
Don't move point in vc-dir on vc-register/vc-checkin (bug#43188)
authorAndrii Kolomoiets <andreyk.mad@gmail.com>
Thu, 3 Sep 2020 19:13:36 +0000 (22:13 +0300)
committerDmitry Gutov <dgutov@yandex.ru>
Fri, 4 Sep 2020 21:16:39 +0000 (00:16 +0300)
* lisp/vc/vc-dir.el (vc-dir-update):
  Save and restore point on 'ewoc-invalidate'.
* lisp/vc/vc-dispatcher.el (vc-finish-logentry):
  Don't call 'vc-dir-move-to-goal-column'.
* lisp/vc/vc.el (vc-register): Don't call 'vc-dir-move-to-goal-column'.

lisp/vc/vc-dir.el
lisp/vc/vc-dispatcher.el
lisp/vc/vc.el

index cdf8ab984e8697e7bc6d6374c59cdc3aa887f3bb..6c219005ceac05da4e0f5832fbac9a1cde4d5d2f 100644 (file)
@@ -451,7 +451,11 @@ If NOINSERT, ignore elements on ENTRIES which are not in the ewoc."
                      (setf (vc-dir-fileinfo->state (ewoc-data node)) (nth 1 entry))
                      (setf (vc-dir-fileinfo->extra (ewoc-data node)) (nth 2 entry))
                      (setf (vc-dir-fileinfo->needs-update (ewoc-data node)) nil)
-                     (ewoc-invalidate vc-ewoc node))
+                      ;; `ewoc-invalidate' will kill line and insert new text,
+                      ;; let's keep point column.
+                      (let ((p (point)))
+                       (ewoc-invalidate vc-ewoc node)
+                        (goto-char p)))
                  ;; If the state is nil, the file does not exist
                  ;; anymore, so remember the entry so we can remove
                  ;; it after we are done inserting all ENTRIES.
index 4a04c9365a5fa333ab1a0e99c358dea94ac737b3..99bf5bf9b641b9050cfd2d031468faf740633136 100644 (file)
@@ -691,7 +691,6 @@ BACKEND, if non-nil, specifies a VC backend for the Log Edit buffer."
        (message "%s  Type C-c C-c when done" msg)
       (vc-finish-logentry (eq comment t)))))
 
-(declare-function vc-dir-move-to-goal-column "vc-dir" ())
 ;; vc-finish-logentry is typically called from a log-edit buffer (see
 ;; vc-start-logentry).
 (defun vc-finish-logentry (&optional nocomment)
@@ -740,8 +739,6 @@ the buffer contents as a comment."
       (mapc
        (lambda (file) (vc-resynch-buffer file t t))
        log-fileset))
-    (when (vc-dispatcher-browsing)
-      (vc-dir-move-to-goal-column))
     (run-hooks after-hook 'vc-finish-logentry-hook)))
 
 (defun vc-dispatcher-browsing ()
index 5561292d8c0330cfc8f602c862a59f073c353d3a..f0a08044e28e0fc7ed9b5a9af89ec4a6c77944f8 100644 (file)
@@ -1346,8 +1346,6 @@ For old-style locking-based version control systems, like RCS:
        nil t)))))
   (vc-call-backend backend 'create-repo))
 
-(declare-function vc-dir-move-to-goal-column "vc-dir" ())
-
 ;;;###autoload
 (defun vc-register (&optional vc-fileset comment)
   "Register into a version control system.
@@ -1398,8 +1396,6 @@ first backend that could register the file is used."
 
        (vc-resynch-buffer file t t))
      files)
-    (when (derived-mode-p 'vc-dir-mode)
-      (vc-dir-move-to-goal-column))
     (message "Registering %s... done" files)))
 
 (defun vc-register-with (backend)