]> git.eshelyaron.com Git - emacs.git/commitdiff
(track-changes--call-signal): Silence late signals
authorStefan Monnier <monnier@iro.umontreal.ca>
Sat, 20 Apr 2024 02:19:00 +0000 (22:19 -0400)
committerEshel Yaron <me@eshelyaron.com>
Sat, 20 Apr 2024 11:10:54 +0000 (14:10 +0300)
* lisp/emacs-lisp/track-changes.el (track-changes--call-signal):
Skip the call if the tracker was unregistered.

(cherry picked from commit 71d2ec7aba3d6ef9386e807970b0bfaa2043d128)

lisp/emacs-lisp/track-changes.el

index c11c976312b01b60ee4bfb24b67914f7984619bd..ac7a99f3c3cbdccb2317220067c882143b506e01 100644 (file)
@@ -364,7 +364,7 @@ and re-enable the TRACKER corresponding to ID."
           (setf (track-changes--tracker-state id) track-changes--state)
           (funcall func beg end (or before lenbefore)))
       ;; Re-enable the tracker's signal only after running `func', so
-      ;; as to avoid recursive invocations.
+      ;; as to avoid nested invocations.
       (cl-pushnew id track-changes--clean-trackers))))
 
 ;;;; Auxiliary functions.
@@ -578,8 +578,10 @@ Details logged to `track-changes--error-log'")
 (defun track-changes--call-signal (buf tracker)
   (when (buffer-live-p buf)
     (with-current-buffer buf
-      ;; Silence ourselves if `track-changes-fetch' was called in the mean time.
-      (unless (memq tracker track-changes--clean-trackers)
+      ;; Silence ourselves if `track-changes-fetch' was called
+      ;; or the tracker was unregistered in the mean time.
+      (when (and (not (memq tracker track-changes--clean-trackers))
+                 (memq tracker track-changes--trackers))
         (funcall (track-changes--tracker-signal tracker) tracker)))))
 
 ;;;; Extra candidates for the API.