* [PATCH] Use vtable for eww-bookmarks @ 2024-11-05 22:53 Sebastián Monía 2024-11-06 12:21 ` Eli Zaretskii 2024-11-23 19:12 ` Jim Porter 0 siblings, 2 replies; 44+ messages in thread From: Sebastián Monía @ 2024-11-05 22:53 UTC (permalink / raw) To: emacs-devel; +Cc: Jim Porter [-- Attachment #1: Type: text/plain, Size: 357 bytes --] Hi all, The attached patch is a first attempt at bringing eww-bookmarks in line with the previous switch of eww-buffer-list to vtable. There are features of eww-bookmarks I had no idea about, like the ability to re-arrange them by killing and yaking. Or navigating to the next bookmark from an eww buffer or invoking the command via M-x. Thank you, Seb [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: vtable-eww-bookmarks --] [-- Type: text/x-patch, Size: 9296 bytes --] From df509a792a58c5eedd1f516c406378315c8d95ca Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20Mon=C3=ADa?= <sebastian.monia@sebasmonia.com> Date: Tue, 5 Nov 2024 17:48:56 -0500 Subject: [PATCH] Use vtable in eww-list-bookmarks * lisp/net/eww.el (eww-list-bookmarks): Move logic to...: (eww--bookmark-prepare, eww--bookmark-format-data ) ... these, and use 'vtable'. (eww-bookmark-kill, eww-bookmark-yank, eww-bookmark-browse, eww-next-bookmark, eww-previous-bookmark, eww-buffers-mode-map): Use 'vtable-current-object'. (eww-bookmark-undo-sort): New command to revert bookmark table sort --- lisp/net/eww.el | 174 +++++++++++++++++++++++++++--------------------- 1 file changed, 98 insertions(+), 76 deletions(-) diff --git a/lisp/net/eww.el b/lisp/net/eww.el index 2d351dff88f..10a7663efc5 100644 --- a/lisp/net/eww.el +++ b/lisp/net/eww.el @@ -2373,115 +2373,124 @@ eww-read-bookmarks (user-error "No bookmarks are defined")))) ;;;###autoload -(defun eww-list-bookmarks () - "Display the bookmarks." +(defun eww-list-bookmarks (&optional build-only) + "Display the eww bookmarks. +Optional argument BUILD-ONLY, when non-nil, means to build the buffer +without popping it." (interactive) (eww-read-bookmarks t) - (pop-to-buffer "*eww bookmarks*") - (eww-bookmark-prepare)) - -(defun eww-bookmark-prepare () - (set-buffer (get-buffer-create "*eww bookmarks*")) - (eww-bookmark-mode) - (let* ((width (/ (window-width) 2)) - (format (format "%%-%ds %%s" width)) - (inhibit-read-only t) - start title) + (with-current-buffer (get-buffer-create "*eww bookmarks*") + (eww-bookmark-mode) + (eww--bookmark-prepare)) + (unless build-only + (pop-to-buffer "*eww bookmarks*"))) + +(defun eww--bookmark-prepare () + "Display a table with the list of eww bookmarks. +Will remove all buffer contents first." + (let ((inhibit-read-only t)) (erase-buffer) - (setq header-line-format (concat " " (format format "Title" "URL"))) - (dolist (bookmark eww-bookmarks) - (setq start (point) - title (plist-get bookmark :title)) - (when (> (length title) width) - (setq title (truncate-string-to-width title width))) - (insert (format format title (plist-get bookmark :url)) "\n") - (put-text-property start (1+ start) 'eww-bookmark bookmark)) - (goto-char (point-min)))) + (make-vtable + :columns '((:name "Title" :min-width "25%" :max-width "50%") + (:name "URL")) + :objects-function #'eww--bookmark-format-data + ;; use fixed-font face + :face 'default))) + +(defun eww--bookmark-format-data () + "Format `eww-bookmarks' for use in a vtable. +The data is returned as list of (title url bookmark) triplets, for use +in of `eww-bookmark-mode'." + (mapcar (lambda (bm) + (list (plist-get bm :title) + (plist-get bm :url) + bm)) + eww-bookmarks)) (defvar eww-bookmark-kill-ring nil) +(defun eww--bookmark-abort-if-sorted () + "Signal a user error if the bookmark vtable at point has been sorted." + (when (and (vtable-current-table) + (vtable-sort-by (vtable-current-table))) + (user-error "Can't kill/yank bookmarks after the table has been sorted"))) + (defun eww-bookmark-kill () "Kill the current bookmark." (interactive nil eww-bookmark-mode) - (let* ((start (line-beginning-position)) - (bookmark (get-text-property start 'eww-bookmark)) - (inhibit-read-only t)) - (unless bookmark + (eww--bookmark-abort-if-sorted) + (let ((bookmark-at-point (nth 2 (vtable-current-object))) + (position (point))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (forward-line 1) - (push (buffer-substring start (point)) eww-bookmark-kill-ring) - (delete-region start (point)) - (setq eww-bookmarks (delq bookmark eww-bookmarks)) - (eww-write-bookmarks))) + (push bookmark-at-point eww-bookmark-kill-ring) + (setq eww-bookmarks (delq bookmark-at-point eww-bookmarks)) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-yank () "Yank a previously killed bookmark to the current line." (interactive nil eww-bookmark-mode) + (eww--bookmark-abort-if-sorted) (unless eww-bookmark-kill-ring (user-error "No previously killed bookmark")) - (beginning-of-line) - (let ((inhibit-read-only t) - (start (point)) - bookmark) - (insert (pop eww-bookmark-kill-ring)) - (setq bookmark (get-text-property start 'eww-bookmark)) - (if (= start (point-min)) - (push bookmark eww-bookmarks) - (let ((line (count-lines start (point)))) - (setcdr (nthcdr (1- line) eww-bookmarks) - (cons bookmark (nthcdr line eww-bookmarks))))) - (eww-write-bookmarks))) + (let* ((bookmark-at-point (nth 2 (vtable-current-object))) + (index-bap (seq-position eww-bookmarks bookmark-at-point)) + (position (point))) + ;; TODO: a simpler way of doing this? + (setq eww-bookmarks (seq-concatenate + 'list + (seq-subseq eww-bookmarks 0 index-bap) + (list (pop eww-bookmark-kill-ring)) + (seq-subseq eww-bookmarks index-bap))) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-browse () "Browse the bookmark under point in eww." (interactive nil eww-bookmark-mode) - (let ((bookmark (get-text-property (line-beginning-position) 'eww-bookmark))) - (unless bookmark + (let ((bookmark-at-point (nth 2 (vtable-current-object)))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (quit-window) - (eww-browse-url (plist-get bookmark :url)))) + (eww-browse-url (plist-get bookmark-at-point :url)))) (defun eww-next-bookmark () "Go to the next bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (when (and (not first) - (not (eobp))) - (forward-line 1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark)) - (unless bookmark - (user-error "No next bookmark"))) - (eww-browse-url (plist-get bookmark :url)))) + (unless fresh-buffer + (forward-line 1)) + (setq target-bookmark (nth 2 (vtable-current-object)))) + (unless target-bookmark + ;; usually because we moved past end of the table + (user-error "No next bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-previous-bookmark () "Go to the previous bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (if first - (goto-char (point-max)) - (beginning-of-line)) - ;; On the final line. - (when (eolp) - (forward-line -1)) - (if (bobp) - (user-error "No previous bookmark") - (forward-line -1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark))) - (eww-browse-url (plist-get bookmark :url)))) + (when fresh-buffer + (vtable-end-of-table)) + ;; didn't move to a previous line, because we + ;; were already on the first one + (unless (= -1 (forward-line -1)) + (setq target-bookmark (nth 2 (vtable-current-object))))) + (unless target-bookmark + (user-error "No previous bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-bookmark-urls () "Get the URLs from the current list of bookmarks." @@ -2489,16 +2498,29 @@ eww-bookmark-urls (eww-read-bookmarks) (mapcar (lambda (x) (plist-get x :url)) eww-bookmarks)) +(defun eww-bookmark-undo-sort () + "Remove any sorting by column of the bookmarks vtable. +This is required before killing and yanking bookmarks to re-arrange +them." + (interactive) + (let ((bookmark-at-point (vtable-current-object))) + (setf (vtable-sort-by (vtable-current-table)) nil) + (vtable-revert-command) + (while (not (equal (vtable-current-object) + bookmark-at-point)) + (forward-line 1)))) + (defvar-keymap eww-bookmark-mode-map "C-k" #'eww-bookmark-kill "C-y" #'eww-bookmark-yank + "u" #'eww-bookmark-undo-sort "RET" #'eww-bookmark-browse :menu '("Eww Bookmark" ["Exit" quit-window t] ["Browse" eww-bookmark-browse - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 2 (vtable-current-object))] ["Kill" eww-bookmark-kill - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 2 (vtable-current-object))] ["Yank" eww-bookmark-yank :active eww-bookmark-kill-ring])) -- 2.45.2.windows.1 [-- Attachment #3: Type: text/plain, Size: 56 bytes --] -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply related [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-05 22:53 [PATCH] Use vtable for eww-bookmarks Sebastián Monía @ 2024-11-06 12:21 ` Eli Zaretskii 2024-11-06 13:36 ` Sebastián Monía 2024-11-23 19:12 ` Jim Porter 1 sibling, 1 reply; 44+ messages in thread From: Eli Zaretskii @ 2024-11-06 12:21 UTC (permalink / raw) To: Sebastián Monía; +Cc: emacs-devel, jporterbugs > From: Sebastián Monía <sebastian@sebasmonia.com> > Cc: Jim Porter <jporterbugs@gmail.com> > Date: Tue, 05 Nov 2024 17:53:44 -0500 > > The attached patch is a first attempt at bringing eww-bookmarks in line > with the previous switch of eww-buffer-list to vtable. > > There are features of eww-bookmarks I had no idea about, like the > ability to re-arrange them by killing and yaking. Or navigating to the > next bookmark from an eww buffer or invoking the command via M-x. I didn't try that, but if it changes the UI and UX, we need to think hard whether we want to surprise users with such changes. What's the rationale and the motivation for this? ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 12:21 ` Eli Zaretskii @ 2024-11-06 13:36 ` Sebastián Monía 2024-11-06 14:33 ` Eli Zaretskii 2024-11-06 14:43 ` Visuwesh 0 siblings, 2 replies; 44+ messages in thread From: Sebastián Monía @ 2024-11-06 13:36 UTC (permalink / raw) To: Eli Zaretskii; +Cc: emacs-devel, jporterbugs [-- Attachment #1: Type: text/plain, Size: 1551 bytes --] Eli Zaretskii <eliz@gnu.org> writes: >> From: Sebastián Monía <sebastian@sebasmonia.com> >> Cc: Jim Porter <jporterbugs@gmail.com> >> Date: Tue, 05 Nov 2024 17:53:44 -0500 >> >> The attached patch is a first attempt at bringing eww-bookmarks in line >> with the previous switch of eww-buffer-list to vtable. >> >> There are features of eww-bookmarks I had no idea about, like the >> ability to re-arrange them by killing and yaking. Or navigating to the >> next bookmark from an eww buffer or invoking the command via M-x. > > I didn't try that, but if it changes the UI and UX, we need to think > hard whether we want to surprise users with such changes. What's the > rationale and the motivation for this? We decided a few weeks ago that to support reverting, the existing 'eww-list-buffers' command could be implemented using a "proper table" mode. The old code worked by inserting text and adding some properties. After some conversation we picked vtable for this. The code was marged recently. During that work I noticed 'eww-list-bookmarks' also used this artisanal approach to building the table, and suggested it would be nice to convert it to vtable, and make it consistent with the new buffer list. This is the patch that follows on that suggestion. Regarding UI/UX changes, there isn't much of a difference on how the table looks. The new one supports sorting though. Although I had to add a binding to "undo sorting", to support an exising feature of eww-bookmarks that lets you re-order the list. [-- Attachment #2: old listing --] [-- Type: image/png, Size: 26637 bytes --] [-- Attachment #3: new listing --] [-- Type: image/png, Size: 27267 bytes --] [-- Attachment #4: new listing, sorted --] [-- Type: image/png, Size: 29674 bytes --] [-- Attachment #5: Type: text/plain, Size: 54 bytes --] -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 13:36 ` Sebastián Monía @ 2024-11-06 14:33 ` Eli Zaretskii 2024-11-06 14:43 ` Visuwesh 1 sibling, 0 replies; 44+ messages in thread From: Eli Zaretskii @ 2024-11-06 14:33 UTC (permalink / raw) To: Sebastián Monía; +Cc: emacs-devel, jporterbugs > From: Sebastián Monía <sebastian@sebasmonia.com> > Cc: emacs-devel@gnu.org, jporterbugs@gmail.com > Date: Wed, 06 Nov 2024 08:36:00 -0500 > > > I didn't try that, but if it changes the UI and UX, we need to think > > hard whether we want to surprise users with such changes. What's the > > rationale and the motivation for this? > > We decided a few weeks ago that to support reverting, the existing > 'eww-list-buffers' command could be implemented using a "proper table" > mode. The old code worked by inserting text and adding some properties. > > After some conversation we picked vtable for this. The code was marged > recently. > > During that work I noticed 'eww-list-bookmarks' also used this artisanal > approach to building the table, and suggested it would be nice to > convert it to vtable, and make it consistent with the new buffer list. > This is the patch that follows on that suggestion. > > Regarding UI/UX changes, there isn't much of a difference on how the > table looks. The new one supports sorting though. Although I had to add > a binding to "undo sorting", to support an exising feature of > eww-bookmarks that lets you re-order the list. Thanks, then I guess there should be no problems with these changes. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 13:36 ` Sebastián Monía 2024-11-06 14:33 ` Eli Zaretskii @ 2024-11-06 14:43 ` Visuwesh 2024-11-06 16:52 ` Sebastián Monía 2024-11-11 7:38 ` Jim Porter 1 sibling, 2 replies; 44+ messages in thread From: Visuwesh @ 2024-11-06 14:43 UTC (permalink / raw) To: Sebastián Monía; +Cc: Eli Zaretskii, emacs-devel, jporterbugs [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: > Eli Zaretskii <eliz@gnu.org> writes: >>> From: Sebastián Monía <sebastian@sebasmonia.com> >>> Cc: Jim Porter <jporterbugs@gmail.com> >>> Date: Tue, 05 Nov 2024 17:53:44 -0500 >>> >>> The attached patch is a first attempt at bringing eww-bookmarks in line >>> with the previous switch of eww-buffer-list to vtable. >>> >>> There are features of eww-bookmarks I had no idea about, like the >>> ability to re-arrange them by killing and yaking. Or navigating to the >>> next bookmark from an eww buffer or invoking the command via M-x. >> >> I didn't try that, but if it changes the UI and UX, we need to think >> hard whether we want to surprise users with such changes. What's the >> rationale and the motivation for this? > > We decided a few weeks ago that to support reverting, the existing > 'eww-list-buffers' command could be implemented using a "proper table" > mode. The old code worked by inserting text and adding some properties. > > After some conversation we picked vtable for this. The code was marged > recently. > > During that work I noticed 'eww-list-bookmarks' also used this artisanal > approach to building the table, and suggested it would be nice to > convert it to vtable, and make it consistent with the new buffer list. > This is the patch that follows on that suggestion. > > Regarding UI/UX changes, there isn't much of a difference on how the > table looks. The new one supports sorting though. Although I had to add > a binding to "undo sorting", to support an exising feature of > eww-bookmarks that lets you re-order the list. Can the -> bitmaps in the fringe be removed from the new listing? It is ugly (and quite misleading too). Or is there a new column that is hidden in the new listing that is not shown in the screenshot? ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 14:43 ` Visuwesh @ 2024-11-06 16:52 ` Sebastián Monía 2024-11-06 20:49 ` Sebastián Monía 2024-11-20 19:27 ` Sebastián Monía 2024-11-11 7:38 ` Jim Porter 1 sibling, 2 replies; 44+ messages in thread From: Sebastián Monía @ 2024-11-06 16:52 UTC (permalink / raw) To: Visuwesh; +Cc: Eli Zaretskii, emacs-devel, jporterbugs Visuwesh <visuweshm@gmail.com> writes: > [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: > > Can the -> bitmaps in the fringe be removed from the new listing? It is > ugly (and quite misleading too). Or is there a new column that is > hidden in the new listing that is not shown in the screenshot? Thanks for the feedback, will look into it. -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 16:52 ` Sebastián Monía @ 2024-11-06 20:49 ` Sebastián Monía 2024-11-07 2:00 ` Visuwesh 2024-11-07 2:00 ` Visuwesh 2024-11-20 19:27 ` Sebastián Monía 1 sibling, 2 replies; 44+ messages in thread From: Sebastián Monía @ 2024-11-06 20:49 UTC (permalink / raw) To: Visuwesh; +Cc: Eli Zaretskii, emacs-devel, jporterbugs Sebastián Monía <sebastian@sebasmonia.com> writes: > Visuwesh <visuweshm@gmail.com> writes: >> [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: >> >> Can the -> bitmaps in the fringe be removed from the new listing? It is >> ugly (and quite misleading too). Or is there a new column that is >> hidden in the new listing that is not shown in the screenshot? > > Thanks for the feedback, will look into it. Turns out that below what's visible in the screenshot, some of the URLs were wider than the windows & frame. When I maximize the frame, the fringe disappears. -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 20:49 ` Sebastián Monía @ 2024-11-07 2:00 ` Visuwesh 2024-11-07 2:00 ` Visuwesh 1 sibling, 0 replies; 44+ messages in thread From: Visuwesh @ 2024-11-07 2:00 UTC (permalink / raw) To: Sebastián Monía; +Cc: Eli Zaretskii, emacs-devel, jporterbugs [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: > Sebastián Monía <sebastian@sebasmonia.com> writes: >> Visuwesh <visuweshm@gmail.com> writes: >>> [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: >>> >>> Can the -> bitmaps in the fringe be removed from the new listing? It is >>> ugly (and quite misleading too). Or is there a new column that is >>> hidden in the new listing that is not shown in the screenshot? >> >> Thanks for the feedback, will look into it. > > Turns out that below what's visible in the screenshot, some of the URLs > were wider than the windows & frame. When I maximize the frame, the > fringe disappears. I see, thank you for the confirmation. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 20:49 ` Sebastián Monía 2024-11-07 2:00 ` Visuwesh @ 2024-11-07 2:00 ` Visuwesh 1 sibling, 0 replies; 44+ messages in thread From: Visuwesh @ 2024-11-07 2:00 UTC (permalink / raw) To: Sebastián Monía; +Cc: Eli Zaretskii, emacs-devel, jporterbugs [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: > Sebastián Monía <sebastian@sebasmonia.com> writes: >> Visuwesh <visuweshm@gmail.com> writes: >>> [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: >>> >>> Can the -> bitmaps in the fringe be removed from the new listing? It is >>> ugly (and quite misleading too). Or is there a new column that is >>> hidden in the new listing that is not shown in the screenshot? >> >> Thanks for the feedback, will look into it. > > Turns out that below what's visible in the screenshot, some of the URLs > were wider than the windows & frame. When I maximize the frame, the > fringe disappears. I see, thank you for the confirmation. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 16:52 ` Sebastián Monía 2024-11-06 20:49 ` Sebastián Monía @ 2024-11-20 19:27 ` Sebastián Monía 1 sibling, 0 replies; 44+ messages in thread From: Sebastián Monía @ 2024-11-20 19:27 UTC (permalink / raw) To: Visuwesh; +Cc: Eli Zaretskii, emacs-devel, jporterbugs Sebastián Monía <sebastian@sebasmonia.com> writes: > Visuwesh <visuweshm@gmail.com> writes: >> [புதன் நவம்பர் 06, 2024] Sebastián Monía wrote: >> >> Can the -> bitmaps in the fringe be removed from the new listing? It is >> ugly (and quite misleading too). Or is there a new column that is >> hidden in the new listing that is not shown in the screenshot? > > Thanks for the feedback, will look into it. I realized today that Jim P. replied to these emails and I replied back without including the rest of the addresses (again, ooops). I said "the reason for the fringe bitmaps was that some table elements were larger than the window width. That's because I made the frame small so the screenshot wasn't too big. And also I didn't capture the whole list, just the top portion." And Jim's reply: > Right. However, the fringe bitmap is present even on rows that would > fit entirely in the window. That's because rows whose last cell is > short have trailing whitespace to fill them out to the max width of > that column. I don't think that trailing whitespace is necessary (at > least not how EWW is using vtable), and if we removed it, you'd only > see the fringe bitmap for individual rows that *don't* fit entirely in > the window. > > - Jim I think we could tackle this vtable issue separate from the eww-bookmark changes. But open to your suggestions. All of you, now that I included everyone 🙃 Thanks, Seb -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-06 14:43 ` Visuwesh 2024-11-06 16:52 ` Sebastián Monía @ 2024-11-11 7:38 ` Jim Porter 1 sibling, 0 replies; 44+ messages in thread From: Jim Porter @ 2024-11-11 7:38 UTC (permalink / raw) To: Visuwesh, Sebastián Monía; +Cc: Eli Zaretskii, emacs-devel, larsi On 11/6/2024 6:43 AM, Visuwesh wrote: > Can the -> bitmaps in the fringe be removed from the new listing? It is > ugly (and quite misleading too). Or is there a new column that is > hidden in the new listing that is not shown in the screenshot? Looking at this, I believe it might be a bug in the vtable code. For every (left-aligned) cell, vtable adds space to the end so it's the same width as the largest cell in that column. That's important for the *non*-last columns of course, but I can't figure out why we need that for the last column. Does anyone know? Could we just remove that space? I think it'd be less misleading without it. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-05 22:53 [PATCH] Use vtable for eww-bookmarks Sebastián Monía 2024-11-06 12:21 ` Eli Zaretskii @ 2024-11-23 19:12 ` Jim Porter 2024-11-27 20:02 ` Sebastián Monía 1 sibling, 1 reply; 44+ messages in thread From: Jim Porter @ 2024-11-23 19:12 UTC (permalink / raw) To: Sebastián Monía, emacs-devel On 11/5/2024 2:53 PM, Sebastián Monía wrote: > Hi all, > > The attached patch is a first attempt at bringing eww-bookmarks in line > with the previous switch of eww-buffer-list to vtable. > > There are features of eww-bookmarks I had no idea about, like the > ability to re-arrange them by killing and yaking. Or navigating to the > next bookmark from an eww buffer or invoking the command via M-x. I think this looks good overall. Just one thought: instead of requiring users to manually undo sorting when killing/yanking, what if we had 'eww-bookmark-kill' and 'eww-yank-bookmark' prompt the user to ask if they want to undo the sorting first? Something like this (untested): (defun eww-bookmark-kill (&optional interactive) (interactive "p") (when (and interactive (vtable-current-table) (vtable-sort-by (vtable-current-table))) (if (y-or-n-p "Reset sorting of bookmarks?") (eww-bookmark-undo-sort) (user-error "Can't kill sorted bookmarks"))) ;; ... ) Then we might not even need a keybinding for 'eww-bookmark-sort'. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-23 19:12 ` Jim Porter @ 2024-11-27 20:02 ` Sebastián Monía 2024-11-28 19:49 ` Jim Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-11-27 20:02 UTC (permalink / raw) To: Jim Porter, emacs-devel On Sat, Nov 23, 2024, at 2:12 PM, Jim Porter wrote: > I think this looks good overall. Just one thought: instead of requiring > users to manually undo sorting when killing/yanking, what if we had > 'eww-bookmark-kill' and 'eww-yank-bookmark' prompt the user to ask if > they want to undo the sorting first? The problem is, when yanking, do you yank the bookmark to the current position on the table? or the one where you will end up after undoing the sort? That (and a few other cases like it) made me opt for having the user disable sorting explicitly. Or even considering just not sorting at all, although it seems like a useful feature for all cases but the kill/yank scenario. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-27 20:02 ` Sebastián Monía @ 2024-11-28 19:49 ` Jim Porter 2024-12-01 5:33 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Jim Porter @ 2024-11-28 19:49 UTC (permalink / raw) To: Sebastián Monía, emacs-devel On 11/27/2024 12:02 PM, Sebastián Monía wrote: > On Sat, Nov 23, 2024, at 2:12 PM, Jim Porter wrote: >> I think this looks good overall. Just one thought: instead of requiring >> users to manually undo sorting when killing/yanking, what if we had >> 'eww-bookmark-kill' and 'eww-yank-bookmark' prompt the user to ask if >> they want to undo the sorting first? > > The problem is, when yanking, do you yank the bookmark to the > current position on the table? or the one where you will end up after > undoing the sort? Good point. For what it's worth, I tried reordering bookmarks in the "Library" window in Firefox, and it works as in your patch: when sorting is active, you can't reorder the bookmarks. Firefox just shows a "No" icon and doesn't let you drag-and-drop. Given that, let's go with your implementation, though I do have one last concern with the "undo sort": the keybinding ("u") is the same as what other table-like modes (e.g. dired, list-packages) use for "unmark". Currently we don't support marking/unmarking in the bookmarks menu, but that seems like a useful thing we might add one day: you could mark several bookmarks in order to open them all, delete them all, add some kind of tag to them, etc. I'm not sure what a better key would be though. Maybe "C" for "clear sort"? ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-11-28 19:49 ` Jim Porter @ 2024-12-01 5:33 ` Sebastián Monía 2024-12-01 6:39 ` Adam Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-01 5:33 UTC (permalink / raw) To: Jim Porter; +Cc: emacs-devel [-- Attachment #1: Type: text/plain, Size: 733 bytes --] Jim Porter <jporterbugs@gmail.com> writes: > Given that, let's go with your implementation, though I do have one > last concern with the "undo sort": the keybinding ("u") is the same as > what other table-like modes (e.g. dired, list-packages) use for > "unmark". Currently we don't support marking/unmarking in the > bookmarks menu, but that seems like a useful thing we might add one > day: you could mark several bookmarks in order to open them all, > delete them all, add some kind of tag to them, etc. This is a good idea. > I'm not sure what a better key would be though. Maybe "C" for "clear sort"? Attached a patch that uses "c" ("c", not "C") and renames the function to match. Let me know what you think! Thanks, Seb [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: New patch --] [-- Type: text/x-patch, Size: 8911 bytes --] From 066a9f856a5d2796a99c1418c7eeefc633ced3ac Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20Mon=C3=ADa?= <code@sebasmonia.com> Date: Sun, 1 Dec 2024 00:29:08 -0500 Subject: [PATCH] Use vtable in eww-list-bookmarks --- lisp/net/eww.el | 174 +++++++++++++++++++++++++++--------------------- 1 file changed, 98 insertions(+), 76 deletions(-) diff --git a/lisp/net/eww.el b/lisp/net/eww.el index 4d4d4d6beac..20c7892e599 100644 --- a/lisp/net/eww.el +++ b/lisp/net/eww.el @@ -2378,115 +2378,124 @@ eww-read-bookmarks (user-error "No bookmarks are defined")))) ;;;###autoload -(defun eww-list-bookmarks () - "Display the bookmarks." +(defun eww-list-bookmarks (&optional build-only) + "Display the eww bookmarks. +Optional argument BUILD-ONLY, when non-nil, means to build the buffer +without popping it." (interactive) (eww-read-bookmarks t) - (pop-to-buffer "*eww bookmarks*") - (eww-bookmark-prepare)) - -(defun eww-bookmark-prepare () - (set-buffer (get-buffer-create "*eww bookmarks*")) - (eww-bookmark-mode) - (let* ((width (/ (window-width) 2)) - (format (format "%%-%ds %%s" width)) - (inhibit-read-only t) - start title) + (with-current-buffer (get-buffer-create "*eww bookmarks*") + (eww-bookmark-mode) + (eww--bookmark-prepare)) + (unless build-only + (pop-to-buffer "*eww bookmarks*"))) + +(defun eww--bookmark-prepare () + "Display a table with the list of eww bookmarks. +Will remove all buffer contents first." + (let ((inhibit-read-only t)) (erase-buffer) - (setq header-line-format (concat " " (format format "Title" "URL"))) - (dolist (bookmark eww-bookmarks) - (setq start (point) - title (plist-get bookmark :title)) - (when (> (length title) width) - (setq title (truncate-string-to-width title width))) - (insert (format format title (plist-get bookmark :url)) "\n") - (put-text-property start (1+ start) 'eww-bookmark bookmark)) - (goto-char (point-min)))) + (make-vtable + :columns '((:name "Title" :min-width "25%" :max-width "50%") + (:name "URL")) + :objects-function #'eww--bookmark-format-data + ;; use fixed-font face + :face 'default))) + +(defun eww--bookmark-format-data () + "Format `eww-bookmarks' for use in a vtable. +The data is returned as list of (title url bookmark) triplets, for use +in of `eww-bookmark-mode'." + (mapcar (lambda (bm) + (list (plist-get bm :title) + (plist-get bm :url) + bm)) + eww-bookmarks)) (defvar eww-bookmark-kill-ring nil) +(defun eww--bookmark-abort-if-sorted () + "Signal a user error if the bookmark vtable at point has been sorted." + (when (and (vtable-current-table) + (vtable-sort-by (vtable-current-table))) + (user-error "Can't kill/yank bookmarks after the table has been sorted"))) + (defun eww-bookmark-kill () "Kill the current bookmark." (interactive nil eww-bookmark-mode) - (let* ((start (line-beginning-position)) - (bookmark (get-text-property start 'eww-bookmark)) - (inhibit-read-only t)) - (unless bookmark + (eww--bookmark-abort-if-sorted) + (let ((bookmark-at-point (nth 2 (vtable-current-object))) + (position (point))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (forward-line 1) - (push (buffer-substring start (point)) eww-bookmark-kill-ring) - (delete-region start (point)) - (setq eww-bookmarks (delq bookmark eww-bookmarks)) - (eww-write-bookmarks))) + (push bookmark-at-point eww-bookmark-kill-ring) + (setq eww-bookmarks (delq bookmark-at-point eww-bookmarks)) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-yank () "Yank a previously killed bookmark to the current line." (interactive nil eww-bookmark-mode) + (eww--bookmark-abort-if-sorted) (unless eww-bookmark-kill-ring (user-error "No previously killed bookmark")) - (beginning-of-line) - (let ((inhibit-read-only t) - (start (point)) - bookmark) - (insert (pop eww-bookmark-kill-ring)) - (setq bookmark (get-text-property start 'eww-bookmark)) - (if (= start (point-min)) - (push bookmark eww-bookmarks) - (let ((line (count-lines start (point)))) - (setcdr (nthcdr (1- line) eww-bookmarks) - (cons bookmark (nthcdr line eww-bookmarks))))) - (eww-write-bookmarks))) + (let* ((bookmark-at-point (nth 2 (vtable-current-object))) + (index-bap (seq-position eww-bookmarks bookmark-at-point)) + (position (point))) + ;; TODO: a simpler way of doing this? + (setq eww-bookmarks (seq-concatenate + 'list + (seq-subseq eww-bookmarks 0 index-bap) + (list (pop eww-bookmark-kill-ring)) + (seq-subseq eww-bookmarks index-bap))) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-browse () "Browse the bookmark under point in eww." (interactive nil eww-bookmark-mode) - (let ((bookmark (get-text-property (line-beginning-position) 'eww-bookmark))) - (unless bookmark + (let ((bookmark-at-point (nth 2 (vtable-current-object)))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (quit-window) - (eww-browse-url (plist-get bookmark :url)))) + (eww-browse-url (plist-get bookmark-at-point :url)))) (defun eww-next-bookmark () "Go to the next bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (when (and (not first) - (not (eobp))) - (forward-line 1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark)) - (unless bookmark - (user-error "No next bookmark"))) - (eww-browse-url (plist-get bookmark :url)))) + (unless fresh-buffer + (forward-line 1)) + (setq target-bookmark (nth 2 (vtable-current-object)))) + (unless target-bookmark + ;; usually because we moved past end of the table + (user-error "No next bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-previous-bookmark () "Go to the previous bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (if first - (goto-char (point-max)) - (beginning-of-line)) - ;; On the final line. - (when (eolp) - (forward-line -1)) - (if (bobp) - (user-error "No previous bookmark") - (forward-line -1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark))) - (eww-browse-url (plist-get bookmark :url)))) + (when fresh-buffer + (vtable-end-of-table)) + ;; didn't move to a previous line, because we + ;; were already on the first one + (unless (= -1 (forward-line -1)) + (setq target-bookmark (nth 2 (vtable-current-object))))) + (unless target-bookmark + (user-error "No previous bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-bookmark-urls () "Get the URLs from the current list of bookmarks." @@ -2494,16 +2503,29 @@ eww-bookmark-urls (eww-read-bookmarks) (mapcar (lambda (x) (plist-get x :url)) eww-bookmarks)) +(defun eww-bookmark-clear-sort () + "Clear any sorting by column of the bookmarks vtable. +This is required before killing and yanking bookmarks to re-arrange +them." + (interactive) + (let ((bookmark-at-point (vtable-current-object))) + (setf (vtable-sort-by (vtable-current-table)) nil) + (vtable-revert-command) + (while (not (equal (vtable-current-object) + bookmark-at-point)) + (forward-line 1)))) + (defvar-keymap eww-bookmark-mode-map "C-k" #'eww-bookmark-kill "C-y" #'eww-bookmark-yank + "c" #'eww-bookmark-clear-sort "RET" #'eww-bookmark-browse :menu '("Eww Bookmark" ["Exit" quit-window t] ["Browse" eww-bookmark-browse - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 2 (vtable-current-object))] ["Kill" eww-bookmark-kill - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 2 (vtable-current-object))] ["Yank" eww-bookmark-yank :active eww-bookmark-kill-ring])) -- 2.47.0 [-- Attachment #3: Type: text/plain, Size: 58 bytes --] -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply related [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-01 5:33 ` Sebastián Monía @ 2024-12-01 6:39 ` Adam Porter 2024-12-01 16:17 ` Sebastián Monía 2024-12-01 19:31 ` Jim Porter 0 siblings, 2 replies; 44+ messages in thread From: Adam Porter @ 2024-12-01 6:39 UTC (permalink / raw) To: sebastian; +Cc: emacs-devel, jporterbugs > Jim Porter <jporterbugs@gmail.com> writes: >> Given that, let's go with your implementation, though I do have one >> last concern with the "undo sort": the keybinding ("u") is the same as >> what other table-like modes (e.g. dired, list-packages) use for >> "unmark". Currently we don't support marking/unmarking in the >> bookmarks menu, but that seems like a useful thing we might add one >> day: you could mark several bookmarks in order to open them all, >> delete them all, add some kind of tag to them, etc. > > This is a good idea. > >> I'm not sure what a better key would be though. Maybe "C" for "clear sort"? > > Attached a patch that uses "c" ("c", not "C") and renames the function > to match. > Let me know what you think! Given how many similar modes and buffers that are in Emacs (i.e. where some kind of objects are displayed in a list with metadata), I think it would be best if any new such feature followed existing paradigms as closely as possible. To have each vtable-like view (whether implemented with vtable or tabulated-list or anything else) have slightly different concepts and bindings is not helpful to the user. So I'd suggest a reconsideration of the concept of sorting: There is no such thing as "clearing" the sorting, because the entries are always sorted by something, even if that's just the order in which the bookmarks are present in the list (which is probably the order in which they were created, or the inverse). As an example, consider Dired: there is no "clearing" of sorting options in Dired, but there is dired-sort-toggle-or-edit: it toggles between sorting by date and sorting by the default (i.e. alphabetically). In this case, the vtable-map already binds vtable-sort-by-current-column. So it seems like what we need is a column by which to sort entries by default. That would seem to leave us with two options: a) Sort by bookmark name by default b) Add a column for the bookmarks' place in the list, and sort by that by default. Then the user could simply sort by one column or the other, without needing to add the additional concept of "clearing" the sorting (a concept that's not generally present in such views in other GUIs, anyway--usually a table view is always sorted by one column or another). And with that, the existing binding of vtable-sort-by-current-column would suffice, eliminating the need for another sort-related binding. What do you think? :) BTW, instead of doing: + (while (not (equal (vtable-current-object) + bookmark-at-point)) + (forward-line 1)))) Could you use vtable-goto-object? I realize that it currently uses EQ for comparison, but 1) we've talked about changing that, and 2) ISTM that EQ should work for this case anyway, because entries in the bookmark list are being compared, and they shouldn't be getting copied. Am I missing something? Thanks, Adam ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-01 6:39 ` Adam Porter @ 2024-12-01 16:17 ` Sebastián Monía 2024-12-01 19:31 ` Jim Porter 1 sibling, 0 replies; 44+ messages in thread From: Sebastián Monía @ 2024-12-01 16:17 UTC (permalink / raw) To: Adam Porter; +Cc: emacs-devel, jporterbugs Adam Porter <adam@alphapapa.net> writes: >> Jim Porter <jporterbugs@gmail.com> writes: >>> I'm not sure what a better key would be though. Maybe "C" for "clear sort"? >> Attached a patch that uses "c" ("c", not "C") and renames the >> function >> to match. >> Let me know what you think! > Given how many similar modes and buffers that are in Emacs (i.e. where > some kind of objects are displayed in a list with metadata), I think > it would be best if any new such feature followed existing paradigms > as closely as possible. To have each vtable-like view (whether > implemented with vtable or tabulated-list or anything else) have > slightly different concepts and bindings is not helpful to the user. There is already some slight differences here and there and it is sometimes jarring, so, great point. For example Gnus uses # for marking, instead of m like vc-dir/dired, sometimes it trips me. > In this case, the vtable-map already binds > vtable-sort-by-current-column. So it seems like what we need is a > column by which to sort entries by default. That would seem to leave > us with two options: > > a) Sort by bookmark name by default > > b) Add a column for the bookmarks' place in the list, and sort by > that by default. The reason the bookmarks order matters, and this killing and yanking feature exists, is that EWW binds M-n and M-p to navigate to the next/prev bookmark. I doubt it is a popular feature (only found out about it when writing this patch...) but I wouldn't remove it. So defaulting to sort by name would be off the table, as it breaks the whole thing. Adding a column "Navigation order", or "rank" (both terrible names, open to suggestions) seems like a great idea. > BTW, instead of doing: > > + (while (not (equal (vtable-current-object) > + bookmark-at-point)) > + (forward-line 1)))) > > Could you use vtable-goto-object? I realize that it currently uses EQ > for comparison, but 1) we've talked about changing that, and 2) ISTM > that EQ should work for this case anyway, because entries in the > bookmark list are being compared, and they shouldn't be getting > copied. Am I missing something? You are not, that code is a 1:1 conversion of the previous code. Next patch, which may include the new column, will make better use of vtable-goto-object when applicable. Thank you! Regards, Seb -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-01 6:39 ` Adam Porter 2024-12-01 16:17 ` Sebastián Monía @ 2024-12-01 19:31 ` Jim Porter 2024-12-01 22:12 ` Sebastián Monía 1 sibling, 1 reply; 44+ messages in thread From: Jim Porter @ 2024-12-01 19:31 UTC (permalink / raw) To: Adam Porter, sebastian; +Cc: emacs-devel On 11/30/2024 10:39 PM, Adam Porter wrote: > So I'd suggest a reconsideration of the concept of sorting: There is no > such thing as "clearing" the sorting, because the entries are always > sorted by something, even if that's just the order in which the > bookmarks are present in the list (which is probably the order in which > they were created, or the inverse). This is probably just a difference of semantics, but I see the default ordering as a non-sorted *ordering*; non-sorted because none of the cells' data contributes to the ordering. The sorted views then apply a sort function to *produce* an ordering. So in my mind you can clear the sorting to reveal the "natural ordering" of the list. > In this case, the vtable-map already binds > vtable-sort-by-current-column. So it seems like what we need is a > column by which to sort entries by default. That would seem to leave us > with two options: > > a) Sort by bookmark name by default > > b) Add a column for the bookmarks' place in the list, and sort by > that by default. I agree that it makes sense to have some common way of handling this so that we don't proliferate many different implementations across Emacs. If we want to let users arbitrarily reorder the entries, then (a) won't work. However, I'm not sure I like (b). Except for providing a command to restore the natural ordering, the list-position column just seems like visual noise. Maybe vtable would benefit from some special handling here? We could even go a step further and make a 'reorderable-vtable' (feel free to suggest a better name/interface) that includes the kill/yank commands from the EWW bookmarks code. Then we can also avoid proliferating many variations on how a user might reorder the data in a table. That said, if everyone else prefers adding a list-position column, I won't fight too hard. I'm not the maintainer for EWW, just someone who's pushed a few commits to it recently. > Then the user could simply sort by one column or the other, without > needing to add the additional concept of "clearing" the sorting (a > concept that's not generally present in such views in other GUIs, > anyway--usually a table view is always sorted by one column or another). For what it's worth, the columns in the bookmarks Library in Firefox are tri-state buttons: sort ascending, sort descending, and no sort. You can only reorder the bookmarks if all the columns have the "no sort" state. Columns in Emacs table modes *can* have any of these three states, but it's not easy to restore the initial ordering. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-01 19:31 ` Jim Porter @ 2024-12-01 22:12 ` Sebastián Monía 2024-12-09 4:52 ` Jim Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-01 22:12 UTC (permalink / raw) To: Jim Porter; +Cc: Adam Porter, emacs-devel Jim Porter <jporterbugs@gmail.com> writes: > Maybe vtable would benefit from some special handling here? We could > even go a step further and make a 'reorderable-vtable' (feel free to > suggest a better name/interface) that includes the kill/yank commands > from the EWW bookmarks code. Then we can also avoid proliferating many > variations on how a user might reorder the data in a table. For the record, a few features in EWW Bookmarks are strange. The kill/yank thing works more as a stack, than how you would expect a kill ring to work (maybe it just needs a different name). Also you can kill a number of items and never yank them, then they are gone. In that aspect it does work as killing I guess. Generalizing this feature can be challenging in that different types of information could need very different handing. Regards, Seb -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-01 22:12 ` Sebastián Monía @ 2024-12-09 4:52 ` Jim Porter 2024-12-10 19:16 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Jim Porter @ 2024-12-09 4:52 UTC (permalink / raw) To: Sebastián Monía; +Cc: Adam Porter, emacs-devel, eliz On 12/1/2024 2:12 PM, Sebastián Monía wrote: > Generalizing this feature can be challenging in that different types of > information could need very different handing. I think in this case, I'll defer to you and Adam (and Eli) about the best path forward here. The existing behavior is a bit odd, and since I don't use EWW's bookmarks, I don't have a good sense of the right way to improve things here. Or in other words, I don't have any objections to the code, but I'm not confident that I know enough about this corner to do a properly thorough review. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-09 4:52 ` Jim Porter @ 2024-12-10 19:16 ` Sebastián Monía 2024-12-12 4:15 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-10 19:16 UTC (permalink / raw) To: Jim Porter; +Cc: Adam Porter, emacs-devel, Eli Zaretskii On Sun, Dec 8, 2024, at 11:52 PM, Jim Porter wrote: > On 12/1/2024 2:12 PM, Sebastián Monía wrote: > > Generalizing this feature can be challenging in that different types of > > information could need very different handing. > > I think in this case, I'll defer to you and Adam (and Eli) about the > best path forward here. The existing behavior is a bit odd, and since I > don't use EWW's bookmarks, I don't have a good sense of the right way to > improve things here. Or in other words, I don't have any objections to > the code, but I'm not confident that I know enough about this corner to > do a properly thorough review. Will submit a patch ASAP to include a column "Order" ("navigation order" is just too long, and I don't think users would associate it with M-n and M-p "navigation"). And then we don't need a "remove sort" binding. Thank you everyone for your feedback! ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-10 19:16 ` Sebastián Monía @ 2024-12-12 4:15 ` Sebastián Monía 2024-12-12 15:25 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-12 4:15 UTC (permalink / raw) To: Jim Porter; +Cc: Adam Porter, emacs-devel, Eli Zaretskii [-- Attachment #1: Type: text/plain, Size: 1166 bytes --] Sebastián Monía <sebastian@sebasmonia.com> writes: > On Sun, Dec 8, 2024, at 11:52 PM, Jim Porter wrote: >> On 12/1/2024 2:12 PM, Sebastián Monía wrote: >> > Generalizing this feature can be challenging in that different types of >> > information could need very different handing. >> >> I think in this case, I'll defer to you and Adam (and Eli) about the >> best path forward here. The existing behavior is a bit odd, and since I >> don't use EWW's bookmarks, I don't have a good sense of the right way to >> improve things here. Or in other words, I don't have any objections to >> the code, but I'm not confident that I know enough about this corner to >> do a properly thorough review. > > Will submit a patch ASAP to include a column "Order". > And then we don't need a "remove sort" binding. Hi all, Attached a patch with "Order" and validation for this sort before kill/yank. As always, open to feedback. @Adam, apparently reverting the vtable re-generates all objects, when using a function (as is our case here). So we can't use `vtable-goto-object' unless the change from eq to equal is applied first. Sad indeed. [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: eww-bookmarks --] [-- Type: text/x-patch, Size: 9149 bytes --] From 840e8039d5e4868c89413f60b08d26d65d8c3ce9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20Mon=C3=ADa?= <code@sebasmonia.com> Date: Sun, 1 Dec 2024 00:29:08 -0500 Subject: [PATCH] Use vtable in eww-list-bookmarks --- lisp/net/eww.el | 174 +++++++++++++++++++++++++++--------------------- 1 file changed, 98 insertions(+), 76 deletions(-) diff --git a/lisp/net/eww.el b/lisp/net/eww.el index 4d4d4d6beac..0a842907bae 100644 --- a/lisp/net/eww.el +++ b/lisp/net/eww.el @@ -2359,6 +2359,7 @@ eww-add-bookmark (plist-get eww-data :title)))) (defun eww-write-bookmarks () + "Write the bookmarks in `eww-bookmarks-directory'." (with-temp-file (expand-file-name "eww-bookmarks" eww-bookmarks-directory) (insert ";; Auto-generated file; don't edit -*- mode: lisp-data -*-\n") (let ((print-length nil) @@ -2378,115 +2379,136 @@ eww-read-bookmarks (user-error "No bookmarks are defined")))) ;;;###autoload -(defun eww-list-bookmarks () - "Display the bookmarks." +(defun eww-list-bookmarks (&optional build-only) + "Display the eww bookmarks. +Optional argument BUILD-ONLY, when non-nil, means to build the buffer +without popping it." (interactive) (eww-read-bookmarks t) - (pop-to-buffer "*eww bookmarks*") - (eww-bookmark-prepare)) - -(defun eww-bookmark-prepare () - (set-buffer (get-buffer-create "*eww bookmarks*")) - (eww-bookmark-mode) - (let* ((width (/ (window-width) 2)) - (format (format "%%-%ds %%s" width)) - (inhibit-read-only t) - start title) + (with-current-buffer (get-buffer-create "*eww bookmarks*") + (eww-bookmark-mode) + (eww--bookmark-prepare)) + (unless build-only + (pop-to-buffer "*eww bookmarks*"))) + +(defun eww--bookmark-prepare () + "Display a table with the list of eww bookmarks. +Will remove all buffer contents first." + (let ((inhibit-read-only t)) (erase-buffer) - (setq header-line-format (concat " " (format format "Title" "URL"))) - (dolist (bookmark eww-bookmarks) - (setq start (point) - title (plist-get bookmark :title)) - (when (> (length title) width) - (setq title (truncate-string-to-width title width))) - (insert (format format title (plist-get bookmark :url)) "\n") - (put-text-property start (1+ start) 'eww-bookmark bookmark)) - (goto-char (point-min)))) + (make-vtable + :columns '((:name "Order" :min-width 6) + (:name "Title" :min-width "25%" :max-width "50%") + (:name "URL")) + :objects-function #'eww--bookmark-format-data + ;; use fixed-font face + :face 'default + :sort-by '((0 . ascend)) + ))) + +(defun eww--bookmark-format-data () + "Format `eww-bookmarks' for use in a vtable. +The data is returned as a list (order title url bookmark), for use +in of `eww-bookmark-mode'. Order stars counting from 1." + (seq-map-indexed (lambda (bm index) + (list + (+ 1 index) + (plist-get bm :title) + (plist-get bm :url) + bm)) + eww-bookmarks)) (defvar eww-bookmark-kill-ring nil) +(defun eww--bookmark-check-order-sort () + "Signal a user error unless the bookmark vtable is sorted by asc order." + ;; vtables sort respecting the previous sort column. As long as + ;; "order" was last, the kill/yank operations will make sense, no + ;; matter what sort was used before. + (when-let* ((the-table (vtable-current-table)) + (last-sort-pair (car (last (vtable-sort-by the-table))))) + (unless (and (= 0 (car last-sort-pair)) + (eq 'ascend (cdr last-sort-pair))) + (user-error + "Can't kill/yank bookmarks unless the table is sorted by ascending Order")))) + (defun eww-bookmark-kill () "Kill the current bookmark." (interactive nil eww-bookmark-mode) - (let* ((start (line-beginning-position)) - (bookmark (get-text-property start 'eww-bookmark)) - (inhibit-read-only t)) - (unless bookmark + (eww--bookmark-check-order-sort) + (let ((bookmark-at-point (nth 3 (vtable-current-object))) + (position (point))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (forward-line 1) - (push (buffer-substring start (point)) eww-bookmark-kill-ring) - (delete-region start (point)) - (setq eww-bookmarks (delq bookmark eww-bookmarks)) - (eww-write-bookmarks))) + (push bookmark-at-point eww-bookmark-kill-ring) + (setq eww-bookmarks (delq bookmark-at-point eww-bookmarks)) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-yank () "Yank a previously killed bookmark to the current line." (interactive nil eww-bookmark-mode) + (eww--bookmark-check-order-sort) (unless eww-bookmark-kill-ring (user-error "No previously killed bookmark")) - (beginning-of-line) - (let ((inhibit-read-only t) - (start (point)) - bookmark) - (insert (pop eww-bookmark-kill-ring)) - (setq bookmark (get-text-property start 'eww-bookmark)) - (if (= start (point-min)) - (push bookmark eww-bookmarks) - (let ((line (count-lines start (point)))) - (setcdr (nthcdr (1- line) eww-bookmarks) - (cons bookmark (nthcdr line eww-bookmarks))))) - (eww-write-bookmarks))) + (let* ((bookmark-at-point (nth 3 (vtable-current-object))) + (index-bap (seq-position eww-bookmarks bookmark-at-point)) + (position (point))) + ;; TODO: a simpler way of doing this? + (setq eww-bookmarks (seq-concatenate + 'list + (seq-subseq eww-bookmarks 0 index-bap) + (list (pop eww-bookmark-kill-ring)) + (seq-subseq eww-bookmarks index-bap))) + (eww-write-bookmarks) + (vtable-revert-command) + (vtable-beginning-of-table) + (goto-char position))) (defun eww-bookmark-browse () "Browse the bookmark under point in eww." (interactive nil eww-bookmark-mode) - (let ((bookmark (get-text-property (line-beginning-position) 'eww-bookmark))) - (unless bookmark + (let ((bookmark-at-point (nth 3 (vtable-current-object)))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (quit-window) - (eww-browse-url (plist-get bookmark :url)))) + (eww-browse-url (plist-get bookmark-at-point :url)))) (defun eww-next-bookmark () "Go to the next bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (when (and (not first) - (not (eobp))) - (forward-line 1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark)) - (unless bookmark - (user-error "No next bookmark"))) - (eww-browse-url (plist-get bookmark :url)))) + (unless fresh-buffer + (forward-line 1)) + (setq target-bookmark (nth 3 (vtable-current-object)))) + (unless target-bookmark + ;; usually because we moved past end of the table + (user-error "No next bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-previous-bookmark () "Go to the previous bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (if first - (goto-char (point-max)) - (beginning-of-line)) - ;; On the final line. - (when (eolp) - (forward-line -1)) - (if (bobp) - (user-error "No previous bookmark") - (forward-line -1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark))) - (eww-browse-url (plist-get bookmark :url)))) + (when fresh-buffer + (vtable-end-of-table)) + ;; didn't move to a previous line, because we + ;; were already on the first one + (unless (= -1 (forward-line -1)) + (setq target-bookmark (nth 3 (vtable-current-object))))) + (unless target-bookmark + (user-error "No previous bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-bookmark-urls () "Get the URLs from the current list of bookmarks." @@ -2501,9 +2523,9 @@ eww-bookmark-mode-map :menu '("Eww Bookmark" ["Exit" quit-window t] ["Browse" eww-bookmark-browse - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 3 (vtable-current-object))] ["Kill" eww-bookmark-kill - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 3 (vtable-current-object))] ["Yank" eww-bookmark-yank :active eww-bookmark-kill-ring])) -- 2.47.0 [-- Attachment #3: Type: text/plain, Size: 58 bytes --] -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply related [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-12 4:15 ` Sebastián Monía @ 2024-12-12 15:25 ` Sebastián Monía 2024-12-12 18:08 ` Adam Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-12 15:25 UTC (permalink / raw) To: Jim Porter; +Cc: Adam Porter, emacs-devel, Eli Zaretskii [-- Attachment #1: Type: text/plain, Size: 236 bytes --] Sebastián Monía <sebastian@sebasmonia.com> writes: > Sebastián Monía <sebastian@sebasmonia.com> writes: > Hi all, > Attached a patch with "Order" and validation for this sort before > kill/yank. > As always, open to feedback. [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: eww-bookmarks --] [-- Type: text/x-patch, Size: 9444 bytes --] From 840e8039d5e4868c89413f60b08d26d65d8c3ce9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20Mon=C3=ADa?= <code@sebasmonia.com> Date: Sun, 1 Dec 2024 00:29:08 -0500 Subject: [PATCH] Use vtable in eww-list-bookmarks * lisp/net/eww.el (eww-list-bookmarks): Move logic to...: (eww--bookmark-prepare, eww--bookmark-format-data ) ... these, and use 'vtable'. (eww-bookmark-kill, eww-bookmark-yank, eww-bookmark-browse, eww-next-bookmark, eww-previous-bookmark, eww-buffers-mode-map): Use 'vtable-current-object'. --- lisp/net/eww.el | 174 +++++++++++++++++++++++++++--------------------- 1 file changed, 98 insertions(+), 76 deletions(-) diff --git a/lisp/net/eww.el b/lisp/net/eww.el index 4d4d4d6beac..0a842907bae 100644 --- a/lisp/net/eww.el +++ b/lisp/net/eww.el @@ -2359,6 +2359,7 @@ eww-add-bookmark (plist-get eww-data :title)))) (defun eww-write-bookmarks () + "Write the bookmarks in `eww-bookmarks-directory'." (with-temp-file (expand-file-name "eww-bookmarks" eww-bookmarks-directory) (insert ";; Auto-generated file; don't edit -*- mode: lisp-data -*-\n") (let ((print-length nil) @@ -2378,115 +2379,136 @@ eww-read-bookmarks (user-error "No bookmarks are defined")))) ;;;###autoload -(defun eww-list-bookmarks () - "Display the bookmarks." +(defun eww-list-bookmarks (&optional build-only) + "Display the eww bookmarks. +Optional argument BUILD-ONLY, when non-nil, means to build the buffer +without popping it." (interactive) (eww-read-bookmarks t) - (pop-to-buffer "*eww bookmarks*") - (eww-bookmark-prepare)) - -(defun eww-bookmark-prepare () - (set-buffer (get-buffer-create "*eww bookmarks*")) - (eww-bookmark-mode) - (let* ((width (/ (window-width) 2)) - (format (format "%%-%ds %%s" width)) - (inhibit-read-only t) - start title) + (with-current-buffer (get-buffer-create "*eww bookmarks*") + (eww-bookmark-mode) + (eww--bookmark-prepare)) + (unless build-only + (pop-to-buffer "*eww bookmarks*"))) + +(defun eww--bookmark-prepare () + "Display a table with the list of eww bookmarks. +Will remove all buffer contents first." + (let ((inhibit-read-only t)) (erase-buffer) - (setq header-line-format (concat " " (format format "Title" "URL"))) - (dolist (bookmark eww-bookmarks) - (setq start (point) - title (plist-get bookmark :title)) - (when (> (length title) width) - (setq title (truncate-string-to-width title width))) - (insert (format format title (plist-get bookmark :url)) "\n") - (put-text-property start (1+ start) 'eww-bookmark bookmark)) - (goto-char (point-min)))) + (make-vtable + :columns '((:name "Order" :min-width 6) + (:name "Title" :min-width "25%" :max-width "50%") + (:name "URL")) + :objects-function #'eww--bookmark-format-data + ;; use fixed-font face + :face 'default + :sort-by '((0 . ascend)) + ))) + +(defun eww--bookmark-format-data () + "Format `eww-bookmarks' for use in a vtable. +The data is returned as a list (order title url bookmark), for use +in of `eww-bookmark-mode'. Order stars counting from 1." + (seq-map-indexed (lambda (bm index) + (list + (+ 1 index) + (plist-get bm :title) + (plist-get bm :url) + bm)) + eww-bookmarks)) (defvar eww-bookmark-kill-ring nil) +(defun eww--bookmark-check-order-sort () + "Signal a user error unless the bookmark vtable is sorted by asc order." + ;; vtables sort respecting the previous sort column. As long as + ;; "order" was last, the kill/yank operations will make sense, no + ;; matter what sort was used before. + (when-let* ((the-table (vtable-current-table)) + (last-sort-pair (car (last (vtable-sort-by the-table))))) + (unless (and (= 0 (car last-sort-pair)) + (eq 'ascend (cdr last-sort-pair))) + (user-error + "Can't kill/yank bookmarks unless the table is sorted by ascending Order")))) + (defun eww-bookmark-kill () "Kill the current bookmark." (interactive nil eww-bookmark-mode) - (let* ((start (line-beginning-position)) - (bookmark (get-text-property start 'eww-bookmark)) - (inhibit-read-only t)) - (unless bookmark + (eww--bookmark-check-order-sort) + (let ((bookmark-at-point (nth 3 (vtable-current-object))) + (position (point))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (forward-line 1) - (push (buffer-substring start (point)) eww-bookmark-kill-ring) - (delete-region start (point)) - (setq eww-bookmarks (delq bookmark eww-bookmarks)) - (eww-write-bookmarks))) + (push bookmark-at-point eww-bookmark-kill-ring) + (setq eww-bookmarks (delq bookmark-at-point eww-bookmarks)) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-yank () "Yank a previously killed bookmark to the current line." (interactive nil eww-bookmark-mode) + (eww--bookmark-check-order-sort) (unless eww-bookmark-kill-ring (user-error "No previously killed bookmark")) - (beginning-of-line) - (let ((inhibit-read-only t) - (start (point)) - bookmark) - (insert (pop eww-bookmark-kill-ring)) - (setq bookmark (get-text-property start 'eww-bookmark)) - (if (= start (point-min)) - (push bookmark eww-bookmarks) - (let ((line (count-lines start (point)))) - (setcdr (nthcdr (1- line) eww-bookmarks) - (cons bookmark (nthcdr line eww-bookmarks))))) - (eww-write-bookmarks))) + (let* ((bookmark-at-point (nth 3 (vtable-current-object))) + (index-bap (seq-position eww-bookmarks bookmark-at-point)) + (position (point))) + ;; TODO: a simpler way of doing this? + (setq eww-bookmarks (seq-concatenate + 'list + (seq-subseq eww-bookmarks 0 index-bap) + (list (pop eww-bookmark-kill-ring)) + (seq-subseq eww-bookmarks index-bap))) + (eww-write-bookmarks) + (vtable-revert-command) + (vtable-beginning-of-table) + (goto-char position))) (defun eww-bookmark-browse () "Browse the bookmark under point in eww." (interactive nil eww-bookmark-mode) - (let ((bookmark (get-text-property (line-beginning-position) 'eww-bookmark))) - (unless bookmark + (let ((bookmark-at-point (nth 3 (vtable-current-object)))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (quit-window) - (eww-browse-url (plist-get bookmark :url)))) + (eww-browse-url (plist-get bookmark-at-point :url)))) (defun eww-next-bookmark () "Go to the next bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (when (and (not first) - (not (eobp))) - (forward-line 1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark)) - (unless bookmark - (user-error "No next bookmark"))) - (eww-browse-url (plist-get bookmark :url)))) + (unless fresh-buffer + (forward-line 1)) + (setq target-bookmark (nth 3 (vtable-current-object)))) + (unless target-bookmark + ;; usually because we moved past end of the table + (user-error "No next bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-previous-bookmark () "Go to the previous bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (if first - (goto-char (point-max)) - (beginning-of-line)) - ;; On the final line. - (when (eolp) - (forward-line -1)) - (if (bobp) - (user-error "No previous bookmark") - (forward-line -1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark))) - (eww-browse-url (plist-get bookmark :url)))) + (when fresh-buffer + (vtable-end-of-table)) + ;; didn't move to a previous line, because we + ;; were already on the first one + (unless (= -1 (forward-line -1)) + (setq target-bookmark (nth 3 (vtable-current-object))))) + (unless target-bookmark + (user-error "No previous bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-bookmark-urls () "Get the URLs from the current list of bookmarks." @@ -2501,9 +2523,9 @@ eww-bookmark-mode-map :menu '("Eww Bookmark" ["Exit" quit-window t] ["Browse" eww-bookmark-browse - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 3 (vtable-current-object))] ["Kill" eww-bookmark-kill - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 3 (vtable-current-object))] ["Yank" eww-bookmark-yank :active eww-bookmark-kill-ring])) -- 2.47.0 [-- Attachment #3: Type: text/plain, Size: 103 bytes --] Updated the patch to include the changelog :) -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply related [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-12 15:25 ` Sebastián Monía @ 2024-12-12 18:08 ` Adam Porter 2024-12-12 19:37 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Adam Porter @ 2024-12-12 18:08 UTC (permalink / raw) To: Sebastián Monía; +Cc: Jim Porter, emacs-devel, Eli Zaretskii [-- Attachment #1: Type: text/plain, Size: 952 bytes --] Sorry, I've been having weird software problems on my system that have made my usual workflows difficult, so I haven't been able to review and process mail very well. Should have them resolved within a few days. It sounds like this patch has proceeded well. About regenerating the elements and not being able to use EQ: is that because the original bookmark objects are not being used as-is? (Sorry, I can't look at the code at the moment.) If so, could we address that? Thanks. On Thu, Dec 12, 2024, 09:25 Sebastián Monía <sebastian@sebasmonia.com> wrote: > Sebastián Monía <sebastian@sebasmonia.com> writes: > > > Sebastián Monía <sebastian@sebasmonia.com> writes: > > Hi all, > > Attached a patch with "Order" and validation for this sort before > > kill/yank. > > As always, open to feedback. > > > Updated the patch to include the changelog :) > > -- > Sebastián Monía > https://site.sebasmonia.com/ > [-- Attachment #2: Type: text/html, Size: 1692 bytes --] ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-12 18:08 ` Adam Porter @ 2024-12-12 19:37 ` Sebastián Monía 2024-12-28 11:04 ` Eli Zaretskii 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-12 19:37 UTC (permalink / raw) To: Adam Porter; +Cc: Jim Porter, emacs-devel, Eli Zaretskii Adam Porter <adam@alphapapa.net> writes: > About regenerating the elements and not being able to use EQ: is that > because the original bookmark objects are not being used as-is? Correct. > If so, could we address that? We could add the order in the file format. Or number the items when we read them. Then use the object including the number to track it all. But when change the "order" number associated with a row, then it won't be eq/equal anymore, anyway. Maybe better: vtable provides a mechanism to have a printer function called on each row. Then the objects stay the same, in the `eq' sense, and we can keep the counter for order outside the row, as part of the printer/"formatter" (in vtable parlance). To consider: then we would call a function for each printed row vs calling it once to generate the list in one go. Plus the code to update the items order number when removing and inserting each one. Of course the real answer on which one is "faster" or "leaner" needs a benchmark. For 90% of cases the amount of bookmarks won't be more than a couple dozen, so I don't think it will matter. I would leave it as-is on the grounds of (add less code + the speed/memory difference is small)(1). But as usual, if there's consensus that we rather do the outlined above instead, I'll do it. (1) like I said, no benchmark, so "_I assume_ the difference is small" > On Thu, Dec 12, 2024, 09:25 Sebastián Monía <sebastian@sebasmonia.com> wrote: > > Sebastián Monía <sebastian@sebasmonia.com> writes: > > > Sebastián Monía <sebastian@sebasmonia.com> writes: > > Hi all, > > Attached a patch with "Order" and validation for this sort before > > kill/yank. > > As always, open to feedback. > > Updated the patch to include the changelog :) > > -- > Sebastián Monía > https://site.sebasmonia.com/ > -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-12 19:37 ` Sebastián Monía @ 2024-12-28 11:04 ` Eli Zaretskii 2024-12-31 0:07 ` Jim Porter 0 siblings, 1 reply; 44+ messages in thread From: Eli Zaretskii @ 2024-12-28 11:04 UTC (permalink / raw) To: adam, Sebastián Monía; +Cc: jporterbugs, emacs-devel Ping! Can we please make some progress here? > From: Sebastián Monía <sebastian@sebasmonia.com> > Cc: Jim Porter <jporterbugs@gmail.com>, emacs-devel <emacs-devel@gnu.org>, > Eli Zaretskii <eliz@gnu.org> > Date: Thu, 12 Dec 2024 14:37:23 -0500 > > Adam Porter <adam@alphapapa.net> writes: > > About regenerating the elements and not being able to use EQ: is that > > because the original bookmark objects are not being used as-is? > > Correct. > > > If so, could we address that? > > We could add the order in the file format. Or number the items when we > read them. Then use the object including the number to track it all. > But when change the "order" number associated with a row, then it won't > be eq/equal anymore, anyway. > > Maybe better: vtable provides a mechanism to have a printer function > called on each row. Then the objects stay the same, in the `eq' sense, > and we can keep the counter for order outside the row, as part of the > printer/"formatter" (in vtable parlance). > > To consider: then we would call a function for each printed row vs > calling it once to generate the list in one go. Plus the code to update > the items order number when removing and inserting each one. > > Of course the real answer on which one is "faster" or "leaner" needs a > benchmark. For 90% of cases the amount of bookmarks won't be more than a > couple dozen, so I don't think it will matter. > > I would leave it as-is on the grounds of (add less code + the > speed/memory difference is small)(1). But as usual, if there's > consensus that we rather do the outlined above instead, I'll do it. > > > (1) like I said, no benchmark, so "_I assume_ the difference is small" > > > On Thu, Dec 12, 2024, 09:25 Sebastián Monía <sebastian@sebasmonia.com> wrote: > > > > Sebastián Monía <sebastian@sebasmonia.com> writes: > > > > > Sebastián Monía <sebastian@sebasmonia.com> writes: > > > Hi all, > > > Attached a patch with "Order" and validation for this sort before > > > kill/yank. > > > As always, open to feedback. > > > > Updated the patch to include the changelog :) > > > > -- > > Sebastián Monía > > https://site.sebasmonia.com/ > > > > -- > Sebastián Monía > https://site.sebasmonia.com/ > ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-28 11:04 ` Eli Zaretskii @ 2024-12-31 0:07 ` Jim Porter 2024-12-31 5:43 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Jim Porter @ 2024-12-31 0:07 UTC (permalink / raw) To: Eli Zaretskii, adam, Sebastián Monía; +Cc: emacs-devel On 12/28/2024 3:04 AM, Eli Zaretskii wrote: > Ping! Can we please make some progress here? In the interest of making progress on this, does anyone have any *objections* to this patch? How about we wait a few days for anyone with objections to make them known, and if not, we just merge the current patch? Once we do that, we can announce the change in a new thread on this list just to give people another chance to raise any objections. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-31 0:07 ` Jim Porter @ 2024-12-31 5:43 ` Sebastián Monía 2024-12-31 18:29 ` Adam Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2024-12-31 5:43 UTC (permalink / raw) To: Jim Porter; +Cc: Eli Zaretskii, adam, emacs-devel Jim Porter <jporterbugs@gmail.com> writes: > On 12/28/2024 3:04 AM, Eli Zaretskii wrote: >> Ping! Can we please make some progress here? > > In the interest of making progress on this, does anyone have any > *objections* to this patch? How about we wait a few days for anyone > with objections to make them known, and if not, we just merge the > current patch? > > Once we do that, we can announce the change in a new thread on this > list just to give people another chance to raise any objections. Hi all, I am open to comments, suggestions, as mentioned in my last reply. I still don't think it is worth it to re-use the bookmark list, but if there's consensus to change, I will do it. Thanks everyone, Seb -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-31 5:43 ` Sebastián Monía @ 2024-12-31 18:29 ` Adam Porter 2024-12-31 20:10 ` [External] : " Drew Adams 2025-01-02 4:25 ` Sebastián Monía 0 siblings, 2 replies; 44+ messages in thread From: Adam Porter @ 2024-12-31 18:29 UTC (permalink / raw) To: Sebastián Monía; +Cc: Jim Porter, Eli Zaretskii, emacs-devel [-- Attachment #1: Type: text/plain, Size: 1876 bytes --] FWIW, I'd recommend using the vtable printer function, as described earlier, so the real records/values can be used and compared as-is. (Apologies if I was unclear earlier, as I thought that was what was already being done.) But I don't have time to contribute code to this patch now, so that's just my recommendation. Also FWIW, I think the long-term goal ought to be to replace EWW's bespoke bookmarks with Emacs bookmarks (i.e. any Emacs bookmark to an HTTP(S) URL ought to be usable by EWW, and it ought to create such bookmarks; EWW should be just another way of opening them). So it would probably be best if the work done could be designed with an eye towards reuse (i.e. using a printer function would mean that the underlying data type could be swapped out later, so this could be just a view of Emacs bookmarks that point to HTTP URLs). My two cents. I won't try to hold up any work or merging for it. Thanks, Adam On Mon, Dec 30, 2024, 23:43 Sebastián Monía <sebastian@sebasmonia.com> wrote: > Jim Porter <jporterbugs@gmail.com> writes: > > > On 12/28/2024 3:04 AM, Eli Zaretskii wrote: > >> Ping! Can we please make some progress here? > > > > In the interest of making progress on this, does anyone have any > > *objections* to this patch? How about we wait a few days for anyone > > with objections to make them known, and if not, we just merge the > > current patch? > > > > Once we do that, we can announce the change in a new thread on this > > list just to give people another chance to raise any objections. > Hi all, > > I am open to comments, suggestions, as mentioned in my last reply. > > I still don't think it is worth it to re-use the bookmark list, but if > there's consensus to change, I will do it. > > Thanks everyone, > Seb > > -- > Sebastián Monía > https://site.sebasmonia.com/ > [-- Attachment #2: Type: text/html, Size: 2506 bytes --] ^ permalink raw reply [flat|nested] 44+ messages in thread
* RE: [External] : Re: [PATCH] Use vtable for eww-bookmarks 2024-12-31 18:29 ` Adam Porter @ 2024-12-31 20:10 ` Drew Adams 2025-01-02 4:25 ` Sebastián Monía 1 sibling, 0 replies; 44+ messages in thread From: Drew Adams @ 2024-12-31 20:10 UTC (permalink / raw) To: Adam Porter, Sebastián Monía Cc: Jim Porter, Eli Zaretskii, emacs-devel [-- Attachment #1: Type: text/plain, Size: 1910 bytes --] (Caveat: Not following this thread.) +1 to using Emacs bookmarks instead of EWW bespoke "bookmarks". (And Org "bookmarks"? Or has that already happened?) FWIW: Bookmark+ has a particular kind of bookmark for EWW pages. * You can use command `bmkp-convert-eww-bookmarks' to create normal bookmarks from a file of EWW "bookmarks". * An EWW bookmark records the web page title, buffer name (see above), and URL. * There's an option for automatic EWW buffer renaming: (1) don't, (2) rename with page title only, (3) rename with page title + last 20 chars of URL. Buffer name always begins with prefix "*eww*-". * There's an option for whether to generate a new buffer or reuse an existing buffer when bookmark jumping. * There's a mode for automatically setting a bookmark when you visit a URL. An option says whether to create a bookmark or just update an existing bookmark to that URL. (Default is update-only.) * For sorting, two EWW bookmarks are compared alphabetically by URL. * All of the Bookmark+ features that act on a given type of bookmark work on EWW bookmarks: jumping, cycling, sorting, hide/show... Besides EWW bookmarks, Bookmark+ has bookmark types for `browse-URL' and W3M. (HTH somehow.) https://www.emacswiki.org/emacs/BookmarkPlus From: Adam Porter Sent: Tuesday, December 31, 2024 10:29 AM ... Also FWIW, I think the long-term goal ought to be to replace EWW's bespoke bookmarks with Emacs bookmarks (i.e. any Emacs bookmark to an HTTP(S) URL ought to be usable by EWW, and it ought to create such bookmarks; EWW should be just another way of opening them). So it would probably be best if the work done could be designed with an eye towards reuse (i.e. using a printer function would mean that the underlying data type could be swapped out later, so this could be just a view of Emacs bookmarks that point to HTTP URLs). [-- Attachment #2: Type: text/html, Size: 11465 bytes --] ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2024-12-31 18:29 ` Adam Porter 2024-12-31 20:10 ` [External] : " Drew Adams @ 2025-01-02 4:25 ` Sebastián Monía 2025-01-07 12:23 ` Sebastián Monía 1 sibling, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2025-01-02 4:25 UTC (permalink / raw) To: Adam Porter; +Cc: Jim Porter, Eli Zaretskii, emacs-devel Adam Porter <adam@alphapapa.net> writes: > Also FWIW, I think the long-term goal ought to be to replace EWW's > bespoke bookmarks with Emacs bookmarks (i.e. any Emacs bookmark to an > HTTP(S) URL ought to be usable by EWW, and it ought to create such > bookmarks; EWW should be just another way of opening them). You can create Emacs bookmarks or EWW bookmarks. I use one or the other for different cases. But that's more a peculiarity of how I work, than proof that we need both, being honest. We could deprecate EWW-only bookmarks, I guess. If we plan to do that, merging this patch makes no sense. And then also drop the feature to re-arrange bookmarks, or make it work in the context of standard bookmarks. Ditto for M-n and M-p to navigate next/prev bookmark in EWW. -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-02 4:25 ` Sebastián Monía @ 2025-01-07 12:23 ` Sebastián Monía 2025-01-07 12:59 ` Adam Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2025-01-07 12:23 UTC (permalink / raw) To: Adam Porter; +Cc: Jim Porter, Eli Zaretskii, emacs-devel Hello everyone! I am ok to retire the patch, with no consensus on how to progress. Regards, Seb On Wed, Jan 1, 2025, at 11:25 PM, Sebastián Monía wrote: > > Adam Porter <adam@alphapapa.net> writes: > > Also FWIW, I think the long-term goal ought to be to replace EWW's > > bespoke bookmarks with Emacs bookmarks (i.e. any Emacs bookmark to an > > HTTP(S) URL ought to be usable by EWW, and it ought to create such > > bookmarks; EWW should be just another way of opening them). > > You can create Emacs bookmarks or EWW bookmarks. I use one or the other > for different cases. But that's more a peculiarity of how I work, than > proof that we need both, being honest. > > We could deprecate EWW-only bookmarks, I guess. If we plan to do that, > merging this patch makes no sense. > And then also drop the feature to re-arrange bookmarks, or make it work > in the context of standard bookmarks. Ditto for M-n and M-p to navigate > next/prev bookmark in EWW. > > -- > Sebastián Monía > https://site.sebasmonia.com/ > > ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 12:23 ` Sebastián Monía @ 2025-01-07 12:59 ` Adam Porter 2025-01-07 18:55 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Adam Porter @ 2025-01-07 12:59 UTC (permalink / raw) To: Sebastián Monía; +Cc: Jim Porter, Eli Zaretskii, emacs-devel [-- Attachment #1: Type: text/plain, Size: 1821 bytes --] I don't think it's necessary to retire it. Your patch is an improvement, no? If it's a step in the right direction, then why not proceed? Further improvements can be made later. AFAIK we're not talking about grand features that would be a crime to make changes to later. Most development in Emacs doesn't happen with full consensus anyway, right? Usually someone has an itch to scratch, and unless someone really objects or a procedure is seriously violated, it gets scratched. I've made some suggestions, but they're only suggestions; they aren't conditions for merging. Am I missing something here? :) On Tue, Jan 7, 2025, 06:23 Sebastián Monía <sebastian@sebasmonia.com> wrote: > Hello everyone! > > I am ok to retire the patch, with no consensus on how to progress. > > Regards, > Seb > > On Wed, Jan 1, 2025, at 11:25 PM, Sebastián Monía wrote: > > > > Adam Porter <adam@alphapapa.net> writes: > > > Also FWIW, I think the long-term goal ought to be to replace EWW's > > > bespoke bookmarks with Emacs bookmarks (i.e. any Emacs bookmark to an > > > HTTP(S) URL ought to be usable by EWW, and it ought to create such > > > bookmarks; EWW should be just another way of opening them). > > > > You can create Emacs bookmarks or EWW bookmarks. I use one or the other > > for different cases. But that's more a peculiarity of how I work, than > > proof that we need both, being honest. > > > > We could deprecate EWW-only bookmarks, I guess. If we plan to do that, > > merging this patch makes no sense. > > And then also drop the feature to re-arrange bookmarks, or make it work > > in the context of standard bookmarks. Ditto for M-n and M-p to navigate > > next/prev bookmark in EWW. > > > > -- > > Sebastián Monía > > https://site.sebasmonia.com/ > > > > > [-- Attachment #2: Type: text/html, Size: 2486 bytes --] ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 12:59 ` Adam Porter @ 2025-01-07 18:55 ` Sebastián Monía 2025-01-07 19:27 ` Stefan Kangas 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2025-01-07 18:55 UTC (permalink / raw) To: Adam Porter; +Cc: Jim Porter, Eli Zaretskii, emacs-devel Adam Porter <adam@alphapapa.net> writes: > I don't think it's necessary to retire it. Your patch is an > improvement, no? On a feature that we are, I understand, trying to deprecate. > I've made some suggestions, but they're only suggestions; they aren't > conditions for merging. Yes, my email wasn't so much about your (appreciated and welcomed) suggestions. But lack of movement in this thread which is probably a gauge for interest in the change. > Am I missing something here? :) Was trying to get ahead to having no updates in the thread for a few weeks and having a "ping" to try to make a decision. Again. For the record, my suggestion to drop the changes doesn't come from a place of disappointment or anything like that. Just being practical, if EWW bookmarks will be phased out, it makes sense to let the bookmarks buffer stay as-is :) Thanks, Seb > On Tue, Jan 7, 2025, 06:23 Sebastián Monía <sebastian@sebasmonia.com> wrote: > > Hello everyone! > > I am ok to retire the patch, with no consensus on how to progress. > > Regards, > Seb > > On Wed, Jan 1, 2025, at 11:25 PM, Sebastián Monía wrote: > > > > Adam Porter <adam@alphapapa.net> writes: > > > Also FWIW, I think the long-term goal ought to be to replace EWW's > > > bespoke bookmarks with Emacs bookmarks (i.e. any Emacs bookmark to an > > > HTTP(S) URL ought to be usable by EWW, and it ought to create such > > > bookmarks; EWW should be just another way of opening them). > > > > You can create Emacs bookmarks or EWW bookmarks. I use one or the other > > for different cases. But that's more a peculiarity of how I work, than > > proof that we need both, being honest. > > > > We could deprecate EWW-only bookmarks, I guess. If we plan to do that, > > merging this patch makes no sense. > > And then also drop the feature to re-arrange bookmarks, or make it work > > in the context of standard bookmarks. Ditto for M-n and M-p to navigate > > next/prev bookmark in EWW. -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 18:55 ` Sebastián Monía @ 2025-01-07 19:27 ` Stefan Kangas 2025-01-07 19:41 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Stefan Kangas @ 2025-01-07 19:27 UTC (permalink / raw) To: Sebastián Monía, Adam Porter Cc: Jim Porter, Eli Zaretskii, emacs-devel Sebastián Monía <sebastian@sebasmonia.com> writes: > lack of movement in this thread which is probably a > gauge for interest in the change. (I have no opinion about this change as I didn't follow the discussion, but from the title alone it sounds good to me.) I wouldn't necessarily interpret a lack of replies or a long turnaround time as disinterest. We don't have many people on board who are actively working on reviewing and installing patches, so it might take us quite some time before we can get to your patch. Please keep in mind that all of us are volunteers, and do this in our free time too. Sometimes people forget about things, so feel free to send a ping if we haven't replied within some reasonable amount of time, usually a couple of weeks. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 19:27 ` Stefan Kangas @ 2025-01-07 19:41 ` Sebastián Monía 2025-01-07 21:01 ` Stefan Kangas 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2025-01-07 19:41 UTC (permalink / raw) To: Stefan Kangas; +Cc: Adam Porter, Jim Porter, Eli Zaretskii, emacs-devel Stefan Kangas <stefankangas@gmail.com> writes: > Sebastián Monía <sebastian@sebasmonia.com> writes: > >> lack of movement in this thread which is probably a >> gauge for interest in the change. > > I wouldn't necessarily interpret a lack of replies or a long > turnaround time as disinterest[...] keep in mind that all of us are > volunteers, and do this in our free time too. Yes, this is why I said "probably". Heck, even when I made updates to the patch, sometimes I took a long time to get to it :) But since Eli's latest ping and the subsequent conversation about deprecating EWW's own bookmark mechanism, I am thinking that maybe this isn't worth our collective time. Again, coming from a practical place! Regards, Seb -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 19:41 ` Sebastián Monía @ 2025-01-07 21:01 ` Stefan Kangas 2025-01-07 22:47 ` Jim Porter 2025-01-08 6:02 ` Thierry Volpiatto 0 siblings, 2 replies; 44+ messages in thread From: Stefan Kangas @ 2025-01-07 21:01 UTC (permalink / raw) To: Sebastián Monía Cc: Adam Porter, Jim Porter, Eli Zaretskii, emacs-devel Sebastián Monía <sebastian@sebasmonia.com> writes: > Stefan Kangas <stefankangas@gmail.com> writes: >> Sebastián Monía <sebastian@sebasmonia.com> writes: >> >>> lack of movement in this thread which is probably a >>> gauge for interest in the change. >> >> I wouldn't necessarily interpret a lack of replies or a long >> turnaround time as disinterest[...] keep in mind that all of us are >> volunteers, and do this in our free time too. > > Yes, this is why I said "probably". Heck, even when I made updates to the > patch, sometimes I took a long time to get to it :) > > But since Eli's latest ping and the subsequent conversation about > deprecating EWW's own bookmark mechanism, I am thinking that maybe this > isn't worth our collective time. Again, coming from a practical place! Is there any reason not to merge your latest patch while we wait for deprecating EWW's bookmarks to happen? Adam says that it's already an improvement, and I'd agree if it means replacing bespoke code with using vtable. From a cursory look, I don't see anything controversial in there. Adam also asked for people to speak up if they object to the patch over a week ago, and no one did. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 21:01 ` Stefan Kangas @ 2025-01-07 22:47 ` Jim Porter 2025-01-08 6:02 ` Thierry Volpiatto 1 sibling, 0 replies; 44+ messages in thread From: Jim Porter @ 2025-01-07 22:47 UTC (permalink / raw) To: Stefan Kangas, Sebastián Monía Cc: Adam Porter, Eli Zaretskii, emacs-devel On 1/7/2025 1:01 PM, Stefan Kangas wrote: > Adam also asked for people to speak up if they object to the patch over > a week ago, and no one did. I think that was me. :) (No relation to Adam, though.) From my point of view, let's merge this and announce it in a new thread so anyone who cares get prodded again to take a look. I'll try to do this in the next day or two if I have time, but anyone else who has time before me, feel free to do so first. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-07 21:01 ` Stefan Kangas 2025-01-07 22:47 ` Jim Porter @ 2025-01-08 6:02 ` Thierry Volpiatto 2025-01-08 15:52 ` Adam Porter 2025-01-19 3:34 ` Sebastián Monía 1 sibling, 2 replies; 44+ messages in thread From: Thierry Volpiatto @ 2025-01-08 6:02 UTC (permalink / raw) To: Stefan Kangas Cc: Sebastián Monía, Adam Porter, Jim Porter, Eli Zaretskii, emacs-devel Stefan Kangas <stefankangas@gmail.com> writes: > Sebastián Monía <sebastian@sebasmonia.com> writes: > >> Stefan Kangas <stefankangas@gmail.com> writes: >>> Sebastián Monía <sebastian@sebasmonia.com> writes: >>> >>>> lack of movement in this thread which is probably a >>>> gauge for interest in the change. >>> >>> I wouldn't necessarily interpret a lack of replies or a long >>> turnaround time as disinterest[...] keep in mind that all of us are >>> volunteers, and do this in our free time too. >> >> Yes, this is why I said "probably". Heck, even when I made updates to the >> patch, sometimes I took a long time to get to it :) >> >> But since Eli's latest ping and the subsequent conversation about >> deprecating EWW's own bookmark mechanism, I am thinking that maybe this >> isn't worth our collective time. Again, coming from a practical place! > > Is there any reason not to merge your latest patch while we wait for > deprecating EWW's bookmarks to happen? Adam says that it's already an > improvement, and I'd agree if it means replacing bespoke code with using > vtable. From a cursory look, I don't see anything controversial in > there. > > Adam also asked for people to speak up if they object to the patch over > a week ago, and no one did. If you plan to move to emacs bookmarks, I see no reasons to use vtable, it will complicate conversion of eww bookmarks to bookmarks which is actually trivial. -- Thierry ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-08 6:02 ` Thierry Volpiatto @ 2025-01-08 15:52 ` Adam Porter 2025-01-19 3:34 ` Sebastián Monía 1 sibling, 0 replies; 44+ messages in thread From: Adam Porter @ 2025-01-08 15:52 UTC (permalink / raw) To: Thierry Volpiatto Cc: Stefan Kangas, Sebastián Monía, Jim Porter, Eli Zaretskii, emacs-devel [-- Attachment #1: Type: text/plain, Size: 662 bytes --] > > If you plan to move to emacs bookmarks, I see no reasons to use vtable, > it will complicate conversion of eww bookmarks to bookmarks which is > actually trivial. > I'm not sure what you mean. Vtable should keep the presentation separate from the underlying object type, so changing that later shouldn't be much trouble. ISTM that switching EWW bookmarks into Emacs bookmarks would be a bigger project, because it requires conversion at runtime, likely some UI, documentation, and testing. That's why I suggest not letting that idea stall this patch, because it may or may not even happen, depending on whether anyone feels like doing it anytime soon. > [-- Attachment #2: Type: text/html, Size: 1158 bytes --] ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-08 6:02 ` Thierry Volpiatto 2025-01-08 15:52 ` Adam Porter @ 2025-01-19 3:34 ` Sebastián Monía 2025-01-21 22:51 ` Stefan Kangas 1 sibling, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2025-01-19 3:34 UTC (permalink / raw) To: Thierry Volpiatto Cc: Stefan Kangas, Adam Porter, Jim Porter, Eli Zaretskii, emacs-devel Thierry Volpiatto <thievol@posteo.net> writes: > Stefan Kangas <stefankangas@gmail.com> writes: > >> Is there any reason not to merge your latest patch while we wait for >> deprecating EWW's bookmarks to happen? Adam says that it's already an >> improvement, and I'd agree if it means replacing bespoke code with using >> vtable. From a cursory look, I don't see anything controversial in >> there. >> >> Adam also asked for people to speak up if they object to the patch over >> a week ago, and no one did. > > If you plan to move to emacs bookmarks, I see no reasons to use vtable, > it will complicate conversion of eww bookmarks to bookmarks which is > actually trivial. Adam already hinted it in his reply, but this patch doesn't change the internal representation of EWW-bookmarks. A minor update, I have started using M-n and M-b and relying on the bookmark order to navigate them. We don't have any statistics, of course, but I suspect the feature is largely unknown. It's interesting. I suspect I found it useful because I don't use a feed reader, most people would use elfeed/newsticker instead. It is also relatively easy to write a similar command using the more generic bookmarks. ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-19 3:34 ` Sebastián Monía @ 2025-01-21 22:51 ` Stefan Kangas 2025-01-22 2:36 ` Sebastián Monía 0 siblings, 1 reply; 44+ messages in thread From: Stefan Kangas @ 2025-01-21 22:51 UTC (permalink / raw) To: Sebastián Monía, Thierry Volpiatto Cc: Adam Porter, Jim Porter, Eli Zaretskii, emacs-devel Sebastián Monía <sebastian@sebasmonia.com> writes: > Thierry Volpiatto <thievol@posteo.net> writes: >> Stefan Kangas <stefankangas@gmail.com> writes: >> >>> Is there any reason not to merge your latest patch while we wait for >>> deprecating EWW's bookmarks to happen? Adam says that it's already an >>> improvement, and I'd agree if it means replacing bespoke code with using >>> vtable. From a cursory look, I don't see anything controversial in >>> there. >>> >>> Adam also asked for people to speak up if they object to the patch over >>> a week ago, and no one did. >> >> If you plan to move to emacs bookmarks, I see no reasons to use vtable, >> it will complicate conversion of eww bookmarks to bookmarks which is >> actually trivial. > > Adam already hinted it in his reply, but this patch doesn't change the > internal representation of EWW-bookmarks. > > A minor update, I have started using M-n and M-b and relying on the > bookmark order to navigate them. We don't have any statistics, of > course, but I suspect the feature is largely unknown. > It's interesting. I suspect I found it useful because I don't use a feed > reader, most people would use elfeed/newsticker instead. > It is also relatively easy to write a similar command using the more > generic bookmarks. Could you please resend the latest version of the patch? ^ permalink raw reply [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-21 22:51 ` Stefan Kangas @ 2025-01-22 2:36 ` Sebastián Monía 2025-01-22 3:50 ` Jim Porter 0 siblings, 1 reply; 44+ messages in thread From: Sebastián Monía @ 2025-01-22 2:36 UTC (permalink / raw) To: Stefan Kangas Cc: Thierry Volpiatto, Adam Porter, Jim Porter, Eli Zaretskii, emacs-devel [-- Attachment #1: Type: text/plain, Size: 1508 bytes --] Stefan Kangas <stefankangas@gmail.com> writes: > Sebastián Monía <sebastian@sebasmonia.com> writes: > >> Thierry Volpiatto <thievol@posteo.net> writes: >>> Stefan Kangas <stefankangas@gmail.com> writes: >>> >>>> Is there any reason not to merge your latest patch while we wait for >>>> deprecating EWW's bookmarks to happen? Adam says that it's already an >>>> improvement, and I'd agree if it means replacing bespoke code with using >>>> vtable. From a cursory look, I don't see anything controversial in >>>> there. >>>> >>>> Adam also asked for people to speak up if they object to the patch over >>>> a week ago, and no one did. >>> >>> If you plan to move to emacs bookmarks, I see no reasons to use vtable, >>> it will complicate conversion of eww bookmarks to bookmarks which is >>> actually trivial. >> >> Adam already hinted it in his reply, but this patch doesn't change the >> internal representation of EWW-bookmarks. >> >> A minor update, I have started using M-n and M-b and relying on the >> bookmark order to navigate them. We don't have any statistics, of >> course, but I suspect the feature is largely unknown. >> It's interesting. I suspect I found it useful because I don't use a feed >> reader, most people would use elfeed/newsticker instead. >> It is also relatively easy to write a similar command using the more >> generic bookmarks. > > Could you please resend the latest version of the patch? Attached! This version was sent December 12. [-- Warning: decoded text below may be mangled, UTF-8 assumed --] [-- Attachment #2: Last path (Dec 12) --] [-- Type: text/x-patch, Size: 9444 bytes --] From 840e8039d5e4868c89413f60b08d26d65d8c3ce9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Sebasti=C3=A1n=20Mon=C3=ADa?= <code@sebasmonia.com> Date: Sun, 1 Dec 2024 00:29:08 -0500 Subject: [PATCH] Use vtable in eww-list-bookmarks * lisp/net/eww.el (eww-list-bookmarks): Move logic to...: (eww--bookmark-prepare, eww--bookmark-format-data ) ... these, and use 'vtable'. (eww-bookmark-kill, eww-bookmark-yank, eww-bookmark-browse, eww-next-bookmark, eww-previous-bookmark, eww-buffers-mode-map): Use 'vtable-current-object'. --- lisp/net/eww.el | 174 +++++++++++++++++++++++++++--------------------- 1 file changed, 98 insertions(+), 76 deletions(-) diff --git a/lisp/net/eww.el b/lisp/net/eww.el index 4d4d4d6beac..0a842907bae 100644 --- a/lisp/net/eww.el +++ b/lisp/net/eww.el @@ -2359,6 +2359,7 @@ eww-add-bookmark (plist-get eww-data :title)))) (defun eww-write-bookmarks () + "Write the bookmarks in `eww-bookmarks-directory'." (with-temp-file (expand-file-name "eww-bookmarks" eww-bookmarks-directory) (insert ";; Auto-generated file; don't edit -*- mode: lisp-data -*-\n") (let ((print-length nil) @@ -2378,115 +2379,136 @@ eww-read-bookmarks (user-error "No bookmarks are defined")))) ;;;###autoload -(defun eww-list-bookmarks () - "Display the bookmarks." +(defun eww-list-bookmarks (&optional build-only) + "Display the eww bookmarks. +Optional argument BUILD-ONLY, when non-nil, means to build the buffer +without popping it." (interactive) (eww-read-bookmarks t) - (pop-to-buffer "*eww bookmarks*") - (eww-bookmark-prepare)) - -(defun eww-bookmark-prepare () - (set-buffer (get-buffer-create "*eww bookmarks*")) - (eww-bookmark-mode) - (let* ((width (/ (window-width) 2)) - (format (format "%%-%ds %%s" width)) - (inhibit-read-only t) - start title) + (with-current-buffer (get-buffer-create "*eww bookmarks*") + (eww-bookmark-mode) + (eww--bookmark-prepare)) + (unless build-only + (pop-to-buffer "*eww bookmarks*"))) + +(defun eww--bookmark-prepare () + "Display a table with the list of eww bookmarks. +Will remove all buffer contents first." + (let ((inhibit-read-only t)) (erase-buffer) - (setq header-line-format (concat " " (format format "Title" "URL"))) - (dolist (bookmark eww-bookmarks) - (setq start (point) - title (plist-get bookmark :title)) - (when (> (length title) width) - (setq title (truncate-string-to-width title width))) - (insert (format format title (plist-get bookmark :url)) "\n") - (put-text-property start (1+ start) 'eww-bookmark bookmark)) - (goto-char (point-min)))) + (make-vtable + :columns '((:name "Order" :min-width 6) + (:name "Title" :min-width "25%" :max-width "50%") + (:name "URL")) + :objects-function #'eww--bookmark-format-data + ;; use fixed-font face + :face 'default + :sort-by '((0 . ascend)) + ))) + +(defun eww--bookmark-format-data () + "Format `eww-bookmarks' for use in a vtable. +The data is returned as a list (order title url bookmark), for use +in of `eww-bookmark-mode'. Order stars counting from 1." + (seq-map-indexed (lambda (bm index) + (list + (+ 1 index) + (plist-get bm :title) + (plist-get bm :url) + bm)) + eww-bookmarks)) (defvar eww-bookmark-kill-ring nil) +(defun eww--bookmark-check-order-sort () + "Signal a user error unless the bookmark vtable is sorted by asc order." + ;; vtables sort respecting the previous sort column. As long as + ;; "order" was last, the kill/yank operations will make sense, no + ;; matter what sort was used before. + (when-let* ((the-table (vtable-current-table)) + (last-sort-pair (car (last (vtable-sort-by the-table))))) + (unless (and (= 0 (car last-sort-pair)) + (eq 'ascend (cdr last-sort-pair))) + (user-error + "Can't kill/yank bookmarks unless the table is sorted by ascending Order")))) + (defun eww-bookmark-kill () "Kill the current bookmark." (interactive nil eww-bookmark-mode) - (let* ((start (line-beginning-position)) - (bookmark (get-text-property start 'eww-bookmark)) - (inhibit-read-only t)) - (unless bookmark + (eww--bookmark-check-order-sort) + (let ((bookmark-at-point (nth 3 (vtable-current-object))) + (position (point))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (forward-line 1) - (push (buffer-substring start (point)) eww-bookmark-kill-ring) - (delete-region start (point)) - (setq eww-bookmarks (delq bookmark eww-bookmarks)) - (eww-write-bookmarks))) + (push bookmark-at-point eww-bookmark-kill-ring) + (setq eww-bookmarks (delq bookmark-at-point eww-bookmarks)) + (eww-write-bookmarks) + (vtable-revert-command) + (goto-char position))) (defun eww-bookmark-yank () "Yank a previously killed bookmark to the current line." (interactive nil eww-bookmark-mode) + (eww--bookmark-check-order-sort) (unless eww-bookmark-kill-ring (user-error "No previously killed bookmark")) - (beginning-of-line) - (let ((inhibit-read-only t) - (start (point)) - bookmark) - (insert (pop eww-bookmark-kill-ring)) - (setq bookmark (get-text-property start 'eww-bookmark)) - (if (= start (point-min)) - (push bookmark eww-bookmarks) - (let ((line (count-lines start (point)))) - (setcdr (nthcdr (1- line) eww-bookmarks) - (cons bookmark (nthcdr line eww-bookmarks))))) - (eww-write-bookmarks))) + (let* ((bookmark-at-point (nth 3 (vtable-current-object))) + (index-bap (seq-position eww-bookmarks bookmark-at-point)) + (position (point))) + ;; TODO: a simpler way of doing this? + (setq eww-bookmarks (seq-concatenate + 'list + (seq-subseq eww-bookmarks 0 index-bap) + (list (pop eww-bookmark-kill-ring)) + (seq-subseq eww-bookmarks index-bap))) + (eww-write-bookmarks) + (vtable-revert-command) + (vtable-beginning-of-table) + (goto-char position))) (defun eww-bookmark-browse () "Browse the bookmark under point in eww." (interactive nil eww-bookmark-mode) - (let ((bookmark (get-text-property (line-beginning-position) 'eww-bookmark))) - (unless bookmark + (let ((bookmark-at-point (nth 3 (vtable-current-object)))) + (unless bookmark-at-point (user-error "No bookmark on the current line")) (quit-window) - (eww-browse-url (plist-get bookmark :url)))) + (eww-browse-url (plist-get bookmark-at-point :url)))) (defun eww-next-bookmark () "Go to the next bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (when (and (not first) - (not (eobp))) - (forward-line 1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark)) - (unless bookmark - (user-error "No next bookmark"))) - (eww-browse-url (plist-get bookmark :url)))) + (unless fresh-buffer + (forward-line 1)) + (setq target-bookmark (nth 3 (vtable-current-object)))) + (unless target-bookmark + ;; usually because we moved past end of the table + (user-error "No next bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-previous-bookmark () "Go to the previous bookmark in the list." (interactive nil eww-bookmark-mode) - (let ((first nil) - bookmark) + (let (fresh-buffer target-bookmark) (unless (get-buffer "*eww bookmarks*") - (setq first t) - (eww-read-bookmarks t) - (eww-bookmark-prepare)) + (setq fresh-buffer t) + (eww-list-bookmarks t)) (with-current-buffer "*eww bookmarks*" - (if first - (goto-char (point-max)) - (beginning-of-line)) - ;; On the final line. - (when (eolp) - (forward-line -1)) - (if (bobp) - (user-error "No previous bookmark") - (forward-line -1)) - (setq bookmark (get-text-property (line-beginning-position) - 'eww-bookmark))) - (eww-browse-url (plist-get bookmark :url)))) + (when fresh-buffer + (vtable-end-of-table)) + ;; didn't move to a previous line, because we + ;; were already on the first one + (unless (= -1 (forward-line -1)) + (setq target-bookmark (nth 3 (vtable-current-object))))) + (unless target-bookmark + (user-error "No previous bookmark")) + (eww-browse-url (plist-get target-bookmark :url)))) (defun eww-bookmark-urls () "Get the URLs from the current list of bookmarks." @@ -2501,9 +2523,9 @@ eww-bookmark-mode-map :menu '("Eww Bookmark" ["Exit" quit-window t] ["Browse" eww-bookmark-browse - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 3 (vtable-current-object))] ["Kill" eww-bookmark-kill - :active (get-text-property (line-beginning-position) 'eww-bookmark)] + :active (nth 3 (vtable-current-object))] ["Yank" eww-bookmark-yank :active eww-bookmark-kill-ring])) -- 2.47.0 [-- Attachment #3: Type: text/plain, Size: 58 bytes --] -- Sebastián Monía https://site.sebasmonia.com/ ^ permalink raw reply related [flat|nested] 44+ messages in thread
* Re: [PATCH] Use vtable for eww-bookmarks 2025-01-22 2:36 ` Sebastián Monía @ 2025-01-22 3:50 ` Jim Porter 0 siblings, 0 replies; 44+ messages in thread From: Jim Porter @ 2025-01-22 3:50 UTC (permalink / raw) To: Sebastián Monía, Stefan Kangas Cc: Thierry Volpiatto, Adam Porter, Eli Zaretskii, emacs-devel On 1/21/2025 6:36 PM, Sebastián Monía wrote: > Attached! This version was sent December 12. Thanks for reposting. I ran with this and found the following issues. 1. Killing a bookmark works, but yanking at the end of the buffer produces the following error: Debugger entered--Lisp error: (wrong-type-argument number-or-marker-p nil) seq-subseq(((:url "https://www.fsf.org/" :title "Front Page — Free Software Foundation — working together for free software" :time "Tue Jan 21 19:48:33 2025")) nil) eww-bookmark-yank() funcall-interactively(eww-bookmark-yank) command-execute(eww-bookmark-yank) 2. Killing the last bookmark in the buffer produces this error: Debugger entered--Lisp error: (cl-no-applicable-method vtable-objects-function nil) signal(cl-no-applicable-method (vtable-objects-function nil)) cl-no-applicable-method(#s(cl--generic :name vtable-objects-function :dispatches ((0 #s(cl--generic-generalizer :name eieio--generic-generalizer :priority 50 :tagcode-function cl--generic-struct-tag :specializers-function #f(compiled-function (tag &rest _) #<bytecode 0x137071fd5144f137>)) #s(cl--generic-generalizer :name cl--generic-t-generalizer :priority 0 :tagcode-function #f(compiled-function (name &rest _) #<bytecode 0x111a2082463a1535>) :specializers-function #f(compiled-function (tag &rest _) #<bytecode -0x1a05678245d32db5>)))) :method-table (#s(cl--generic-method :specializers (vtable) :qualifiers nil :call-con nil :function #f(compiled-function (this) "Retrieve the slot `objects-function' from an object of class `vtable'." #<bytecode -0x65b654f1e7958ff>))) :options nil) nil) apply(cl-no-applicable-method #s(cl--generic :name vtable-objects-function :dispatches ((0 #s(cl--generic-generalizer :name eieio--generic-generalizer :priority 50 :tagcode-function cl--generic-struct-tag :specializers-function #f(compiled-function (tag &rest _) #<bytecode 0x137071fd5144f137>)) #s(cl--generic-generalizer :name cl--generic-t-generalizer :priority 0 :tagcode-function #f(compiled-function (name &rest _) #<bytecode 0x111a2082463a1535>) :specializers-function #f(compiled-function (tag &rest _) #<bytecode -0x1a05678245d32db5>)))) :method-table (#s(cl--generic-method :specializers (vtable) :qualifiers nil :call-con nil :function #f(compiled-function (this) "Retrieve the slot `objects-function' from an object of class `vtable'." #<bytecode -0x65b654f1e7958ff>))) :options nil) nil) #f(compiled-function (&rest args) #<bytecode 0x159c15a915096a8f>)(nil) apply(#f(compiled-function (&rest args) #<bytecode 0x159c15a915096a8f>) nil nil) vtable-objects-function(nil) vtable-revert-command() eww-bookmark-kill() funcall-interactively(eww-bookmark-kill) command-execute(eww-bookmark-kill) ^ permalink raw reply [flat|nested] 44+ messages in thread
end of thread, other threads:[~2025-01-22 3:50 UTC | newest] Thread overview: 44+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-11-05 22:53 [PATCH] Use vtable for eww-bookmarks Sebastián Monía 2024-11-06 12:21 ` Eli Zaretskii 2024-11-06 13:36 ` Sebastián Monía 2024-11-06 14:33 ` Eli Zaretskii 2024-11-06 14:43 ` Visuwesh 2024-11-06 16:52 ` Sebastián Monía 2024-11-06 20:49 ` Sebastián Monía 2024-11-07 2:00 ` Visuwesh 2024-11-07 2:00 ` Visuwesh 2024-11-20 19:27 ` Sebastián Monía 2024-11-11 7:38 ` Jim Porter 2024-11-23 19:12 ` Jim Porter 2024-11-27 20:02 ` Sebastián Monía 2024-11-28 19:49 ` Jim Porter 2024-12-01 5:33 ` Sebastián Monía 2024-12-01 6:39 ` Adam Porter 2024-12-01 16:17 ` Sebastián Monía 2024-12-01 19:31 ` Jim Porter 2024-12-01 22:12 ` Sebastián Monía 2024-12-09 4:52 ` Jim Porter 2024-12-10 19:16 ` Sebastián Monía 2024-12-12 4:15 ` Sebastián Monía 2024-12-12 15:25 ` Sebastián Monía 2024-12-12 18:08 ` Adam Porter 2024-12-12 19:37 ` Sebastián Monía 2024-12-28 11:04 ` Eli Zaretskii 2024-12-31 0:07 ` Jim Porter 2024-12-31 5:43 ` Sebastián Monía 2024-12-31 18:29 ` Adam Porter 2024-12-31 20:10 ` [External] : " Drew Adams 2025-01-02 4:25 ` Sebastián Monía 2025-01-07 12:23 ` Sebastián Monía 2025-01-07 12:59 ` Adam Porter 2025-01-07 18:55 ` Sebastián Monía 2025-01-07 19:27 ` Stefan Kangas 2025-01-07 19:41 ` Sebastián Monía 2025-01-07 21:01 ` Stefan Kangas 2025-01-07 22:47 ` Jim Porter 2025-01-08 6:02 ` Thierry Volpiatto 2025-01-08 15:52 ` Adam Porter 2025-01-19 3:34 ` Sebastián Monía 2025-01-21 22:51 ` Stefan Kangas 2025-01-22 2:36 ` Sebastián Monía 2025-01-22 3:50 ` Jim Porter
Code repositories for project(s) associated with this public inbox https://git.savannah.gnu.org/cgit/emacs.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).