emacs-elpa-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[nongnu] elpa/annotate 856ebe246b 020/372: properly ignore non-annotatio


From: ELPA Syncer
Subject: [nongnu] elpa/annotate 856ebe246b 020/372: properly ignore non-annotation overlays
Date: Fri, 4 Feb 2022 16:58:15 -0500 (EST)

branch: elpa/annotate
commit 856ebe246bd592c1523876054188734443b7e1f7
Author: Bastian Bechtold <bb@mo30211.hs-woe.de>
Commit: Bastian Bechtold <bb@mo30211.hs-woe.de>

    properly ignore non-annotation overlays
---
 annotate.el | 22 ++++++++++++++--------
 1 file changed, 14 insertions(+), 8 deletions(-)

diff --git a/annotate.el b/annotate.el
index 3afa814b69..489b299f14 100644
--- a/annotate.el
+++ b/annotate.el
@@ -111,8 +111,7 @@
 (defun annotate-save-annotations ()
   "Save all annotations to disk."
   (interactive)
-  (let ((file-annotations
-         (mapcar 'annotate-describe-annotation (overlays-in 0 (buffer-size))))
+  (let ((file-annotations (annotate-describe-annotations))
         (all-annotations (annotate-load-annotation-data)))
     (if (assoc-string (buffer-file-name) all-annotations)
         (setcdr (assoc-string (buffer-file-name) all-annotations)
@@ -222,12 +221,19 @@
          ((thing-at-point 'symbol) (cdr (bounds-of-thing-at-point 'symbol)))
          (t (1+ (point))))))
 
-(defun annotate-describe-annotation (highlight)
-  "Return list that describes the overlay `highlight`."
-  (list
-   (overlay-start highlight)
-   (overlay-end highlight)
-   (overlay-get highlight 'annotation)))
+(defun annotate-describe-annotations ()
+  "Return a list of all annotations in the current buffer."
+  (let ((overlays (overlays-in 0 (buffer-size))))
+    (setq overlays
+          (remove-if
+           (lambda (ov)
+             (eq nil (overlay-get ov 'annotation)))
+           overlays))
+    (mapcar (lambda (ov)
+              (list (overlay-start ov)
+                    (overlay-end ov)
+                    (overlay-get ov 'annotation)))
+            overlays)))
 
 (defun annotate-load-annotation-data ()
   "Read and return saved annotations."



reply via email to

[Prev in Thread] Current Thread [Next in Thread]