]> git.eshelyaron.com Git - emacs.git/commitdiff
When waiting for processes in Eshell, wait until all the I/O is complete
authorJim Porter <jporterbugs@gmail.com>
Wed, 13 Sep 2023 18:50:39 +0000 (11:50 -0700)
committerJim Porter <jporterbugs@gmail.com>
Wed, 13 Sep 2023 20:37:38 +0000 (13:37 -0700)
This should fix bug#59103, bug#65590, and bug#65601.

* lisp/eshell/esh-proc.el (eshell-sentinel): Set ':eshell-handles' to
nil when finished with I/O.
(eshell-wait-for-process): Wait until ':eshell-handles' is nil.

lisp/eshell/esh-proc.el

index 5df68947ec218dc04634ea4d96495e49d1727999..afd0ed8013299368037fc0f58ff2492981feea9a 100644 (file)
@@ -161,7 +161,11 @@ The signals which will cause this to happen are matched by
   "Wait until PROCS have successfully completed."
   (dolist (proc procs)
     (when (eshell-processp proc)
-      (while (process-live-p proc)
+      (while (or (process-live-p proc)
+                 ;; If we have handles, this is an Eshell-managed
+                 ;; process.  Wait until we're 100% done and have
+                 ;; cleared out the handles (see `eshell-sentinel').
+                 (process-get proc :eshell-handles))
         (when (input-pending-p)
           (discard-input))
         (sit-for eshell-process-wait-seconds
@@ -530,6 +534,9 @@ PROC is the process that's exiting.  STRING is the exit message."
                            status
                            (when status (list 'quote (= status 0)))
                            handles)
+                          ;; Clear the handles to mark that we're 100%
+                          ;; finished with the I/O for this process.
+                          (process-put proc :eshell-handles nil)
                           (eshell-debug-command
                            'process
                            (format-message