From 05f1a90f4299b7c4ef307e48e29917c4c5acd66b Mon Sep 17 00:00:00 2001 From: Damien Elmes Date: Tue, 4 Jul 2006 04:40:00 +0000 Subject: browser: add default covers, fix bug darcs-hash:20060704044020-4e3e3-d0f91c965a5820c1afaa14a4131fd780cc4aed11.gz --- emms-browser.el | 46 ++++++++++++++++++++++++++-------------------- 1 file changed, 26 insertions(+), 20 deletions(-) diff --git a/emms-browser.el b/emms-browser.el index 5aca325..1395cc5 100644 --- a/emms-browser.el +++ b/emms-browser.el @@ -133,6 +133,11 @@ return a path to the cover, or nil to turn off cover loading." :group 'emms-browser :type '(choice list function boolean)) +(defcustom emms-browser-default-covers nil + "*A list of default images to use if a cover isn't found." + :group 'emms-browser + :type 'string) + (defcustom emms-browser-insert-track-function 'emms-browser-insert-track-standard "*A function to insert a track into the playlist. @@ -1188,22 +1193,23 @@ included." "Return a cover filename, if it exists." (unless size (setq size 'medium)) - (let ((cover - (cond - ((functionp emms-browser-covers) - (funcall emms-browser-covers path size)) - ((listp emms-browser-covers) - (concat (file-name-directory path) - (cond - ((eq size 'small) - (nth 0 emms-browser-covers)) - ((eq size 'medium) - (nth 1 emms-browser-covers)) - ((eq size 'large) - (nth 2 emms-browser-covers)))))))) - (when (and cover - (file-readable-p cover)) - cover))) + (let* ((size-idx (cond + ((eq size 'small) 0) + ((eq size 'medium) 1) + ((eq size 'large) 2))) + (cover + (cond + ((functionp emms-browser-covers) + (funcall emms-browser-covers path size)) + ((listp emms-browser-covers) + (concat (file-name-directory path) + (nth size-idx emms-browser-covers)))))) + (if (and cover + (file-readable-p cover)) + cover + ;; no cover found, use default + (when emms-browser-default-covers + (nth size-idx emms-browser-default-covers))))) (defun emms-browser-insert-cover (path) (insert (emms-browser-make-cover path))) @@ -1244,8 +1250,8 @@ included." (defun emms-browser-year-and-album-fmt (bdata fmt) (concat "%cS" - (let ((year (emms-browser-format-elem fmt "%y"))) - (if (and year (not (eq year 0))) + (let ((year (emms-browser-format-elem fmt "y"))) + (if (and year (not (string= year "0"))) "(%y) " "")) "%n")) @@ -1253,8 +1259,8 @@ included." (defun emms-browser-year-and-album-fmt-med (bdata fmt) (concat "%cM" - (let ((year (emms-browser-format-elem fmt "%y"))) - (if (and year (not (eq year 0))) + (let ((year (emms-browser-format-elem fmt "y"))) + (if (and year (not (string= year "0"))) "(%y) " "")) "%n")) -- cgit v1.2.3