Ця функція line-number-at-pos
(коли повторюється приблизно 50 разів) викликає помітне уповільнення в напіввеликих буферах - наприклад, 50000 рядків - коли точка знаходиться в кінці буфера. Під уповільненням я маю на увазі загальну суму приблизно 1,35 секунди.
Замість того, щоб використовувати 100% функціонал elisp
для підрахунку рядків і перейти до верхньої частини буфера, я зацікавився би гібридним методом, який використовує вбудовані здібності C, відповідальні за номер рядка, що відображається в рядку режиму. Номер рядка, який відображається на рядку режиму, відбувається зі швидкістю світла, незалежно від розміру буфера.
Ось функція тесту:
(defmacro measure-time (&rest body)
"Measure the time it takes to evaluate BODY.
http://lists.gnu.org/archive/html/help-gnu-emacs/2008-06/msg00087.html"
`(let ((time (current-time)))
,@body
(message "%.06f" (float-time (time-since time)))))
(measure-time
(let* (
line-numbers
(window-start (window-start))
(window-end (window-end)))
(save-excursion
(goto-char window-end)
(while
(re-search-backward "\n" window-start t)
(push (line-number-at-pos) line-numbers)))
line-numbers))