1
0
mirror of https://codeberg.org/cage/tinmop/ synced 2025-06-05 01:09:17 +02:00

- optimized module 'rewrite-message-urls.lisp'.

This commit is contained in:
cage
2021-04-21 16:29:50 +02:00
parent 0cd1f77c7f
commit 02894dcc64
3 changed files with 33 additions and 16 deletions

View File

@@ -65,25 +65,30 @@ So the whole list is like: '((\"foo\" \"bar\") (\"old\" \"new\") ...)")
(or (message-window:row-invisible-p row)
(find-if (lambda (a) (typep original-type a)) skipped-row-types))))
(defun %rewriting-link-rewrite-row (links-mapping)
(lambda (row)
(let* ((original-string (line-oriented-window:normal-text row)))
(if (skipped-row-p row)
row
(let* ((simple-string (tui:tui-string->chars-string original-string))
(defun rewriting-link-rewrite-row (window index links-mapping)
(with-accessors ((rows line-oriented-window:rows)) window
(when rows
(let* ((row (elt rows index))
(original-string (line-oriented-window:normal-text row)))
(when (not (skipped-row-p row))
(let* ((simple-string (tui:tui-string->chars-string original-string))
(replaced-string simple-string))
(loop for mapping in links-mapping do
(setf replaced-string
(rewriting-link-replace-mapping mapping replaced-string)))
replaced-string)))))
(setf (line-oriented-window:normal-text row)
(message-window::colorize-lines replaced-string))
(setf (elt rows index)
(message-window:text->rendered-lines-rows window row))))))))
(defun rewriting-link-message-hook-fn (message-window)
(let* ((map-fn (%rewriting-link-rewrite-row *rewriting-link-rules*))
(replaced-rows (line-oriented-window:rows-map-raw message-window
map-fn))
(new-rows (message-window:text->rendered-lines-rows message-window
replaced-rows)))
(line-oriented-window:update-all-rows message-window new-rows)))
(multiple-value-bind (x start-visible-index end-visible-index)
(message-window:visible-rows message-window)
(declare (ignore x))
(loop for i from start-visible-index below end-visible-index do
(rewriting-link-rewrite-row message-window i *rewriting-link-rules*))
message-window))
(defun rewriting-link-links-window-hook-fn (all-links)
(let ((links-mapping (rewriting-link-messages-links-rules all-links))