From eefd0abb3cb7ca8a09c249686ff67555724624da Mon Sep 17 00:00:00 2001 From: Thanos Apollo <public@thanosapollo.org> Date: Fri, 15 Nov 2024 12:41:52 +0200 Subject: Rewrite selecting-by-tag * Use gnosis-collect-tag-note-ids to improve performance --- gnosis.el | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) (limited to 'gnosis.el') diff --git a/gnosis.el b/gnosis.el index e051180..aa209e4 100644 --- a/gnosis.el +++ b/gnosis.el @@ -1306,7 +1306,14 @@ Optionally, add cusotm PROMPT." (cl-loop for tags in (gnosis-select 'tags 'notes '1=1 t) nconc tags into all-tags finally return (delete-dups all-tags))) -;; TODO: Rewrite this using gnosis-get-tag-notes. + +(defun gnosis-collect-tag-note-ids (tags &optional ids) + "Collect note IDS for TAGS." + (cl-assert (listp tags)) + (if (null tags) ids + (gnosis-collect-tag-note-ids (cdr tags) + (append ids (gnosis-get-tag-notes (car tags)))))) + (defun gnosis-select-by-tag (input-tags &optional due suspended-p) "Return note ID's for every note with INPUT-TAGS. @@ -1314,11 +1321,12 @@ If DUE, return only due notes. If SUSPENDED-P, return suspended notes as well." (cl-assert (listp input-tags) t "Input tags must be a list") (cl-assert (booleanp due) "Due value must be a boolean") - (cl-loop for (id tags) in (gnosis-select '[id tags] 'notes) - when (and (cl-every (lambda (tag) (member tag tags)) input-tags) - (or (not suspended-p) (not (gnosis-suspended-p id))) - (if due (gnosis-review-is-due-p id) t)) - collect id)) + (let ((ids (gnosis-collect-tag-note-ids input-tags))) + ;; Filter the collected IDs based on due and suspension status + (cl-loop for id in ids + when (and (or (not suspended-p) (not (gnosis-suspended-p id))) + (if due (gnosis-review-is-due-p id) t)) + collect id))) (defun gnosis-get-tag-notes (tag) "Return note ids for TAG." @@ -1763,7 +1771,7 @@ If NEW? is non-nil, increment new notes log by 1." (interactive) (let ((default-directory dir)) (vc-pull) - ;; Fix sync by adding a small delay + ;; Fix sync by adding a small delay, `vc-pull' is async. (sit-for 0.3) ;; Reopen gnosis-db after pull (setf gnosis-db (emacsql-sqlite-open (expand-file-name "gnosis.db" dir))))) @@ -1773,9 +1781,7 @@ If NEW? is non-nil, increment new notes log by 1." This function initializes the `gnosis-dir' as a Git repository if it is not already one. It then adds the gnosis.db file to the repository and commits -the changes with a message containing the reviewed number of notes. - -NOTE-NUM: The number of notes reviewed in the session." +the changes with a message containing the reviewed number NOTE-NUM." (let ((git (executable-find "git")) (default-directory gnosis-dir)) (unless git -- cgit v1.2.3