In what order does Emacs handle simultaneous process sentinels?
Couldn't find this info in the manual.
Answer: The first process that finished is the first one handled.
Verified as follows:
(dotimes (i 10) (make-process :name (format "*%d*" i) :buffer (get-buffer-create (format "*foo-%d*" i) t) :command (list "emacs" "-Q" "--batch" "--eval" (prin1-to-string `(progn (make-list (random 100) (make-list (random 100) t)) (print (format "%dth spawned, finished at %.3fs" ,i (time-to-seconds)))))) :sentinel (lambda (proc _) (with-current-buffer (process-buffer proc) (message "%s" (buffer-string))) (kill-buffer (process-buffer proc)))))
A result:
"6th spawned, finished at 1730132198.780s" "2th spawned, finished at 1730132198.778s" "0th spawned, finished at 1730132198.781s" "1th spawned, finished at 1730132198.803s" "3th spawned, finished at 1730132198.822s" "4th spawned, finished at 1730132198.838s" "9th spawned, finished at 1730132198.842s" "5th spawned, finished at 1730132198.850s" "7th spawned, finished at 1730132198.876s" "8th spawned, finished at 1730132198.900s"
Related
Emacs async process performance
What links here
- 2024-10-28
Created (2 months ago)