Emms: Fix ambrevar/emms-tracks-duration for playlist-mode.

master
Pierre Neidhardt 2020-12-09 13:12:06 +01:00
parent 16bcca9973
commit 831af6f20a
1 changed files with 23 additions and 19 deletions

View File

@ -144,24 +144,28 @@ character."
(defun ambrevar/emms-tracks-duration (begin end)
"Display play time of tracks in region."
(interactive "r")
(if (not (use-region-p))
(message "%s" (emms-browser-track-duration
(car (emms-browser-tracks-at-point))))
(let* ((total-time)
(first-line (line-number-at-pos begin))
(last-line (line-number-at-pos end))
(count 0))
(setq total-time
(save-mark-and-excursion
(cl-loop for line from first-line to last-line
do (goto-line line)
for time = (emms-track-get (car (emms-browser-tracks-at-point))
'info-playing-time)
when time
do (cl-incf count)
when time
sum time)))
(message "%02d:%02d for %d tracks" (/ total-time 60) (% total-time 60)
count))))
(cl-flet ((track-at-point ()
(if (eq major-mode 'emms-playlist-mode)
(emms-playlist-track-at)
(car (emms-browser-tracks-at-point)))))
(if (not (use-region-p))
(message "%s" (emms-browser-track-duration
(track-at-point)))
(let* ((total-time)
(first-line (line-number-at-pos begin))
(last-line (line-number-at-pos end))
(count 0))
(setq total-time
(save-mark-and-excursion
(cl-loop for line from first-line to last-line
do (goto-line line)
for time = (emms-track-get (track-at-point)
'info-playing-time)
when time
do (cl-incf count)
when time
sum time)))
(message "%02d:%02d for %d tracks" (/ total-time 60) (% total-time 60)
count)))))
(provide 'init-emms)