From 0f73de32500bb2cfe99d9fa7fbd730addd67d46a Mon Sep 17 00:00:00 2001 From: Michael Olson Date: Fri, 9 Jun 2006 04:01:00 +0000 Subject: emms-cache: Add standard enable/disable/toggle interface and do a docfix for emms-cache-set-function. darcs-hash:20060609040108-1bfb2-268d7a1f4c7590ffdedcda9506bfca53e02cc2ea.gz --- emms-cache.el | 46 +++++++++++++++++++++++++++++++++++++++++++--- emms-setup.el | 6 +----- emms.el | 3 ++- 3 files changed, 46 insertions(+), 9 deletions(-) diff --git a/emms-cache.el b/emms-cache.el index 60b3b24..dba9fcf 100644 --- a/emms-cache.el +++ b/emms-cache.el @@ -49,12 +49,52 @@ "A mapping of paths to file info. This is used to cache over emacs sessions.") -(defvar emms-cache-file "~/.emms-cache" - "A file used to store cached file info information over sessions") - (defvar emms-cache-dirty nil "True if the cache has been updated since init.") +(defcustom emms-cache-file "~/.emms-cache" + "A file used to store cached file information over sessions." + :group 'emms + :type 'file) + +(defun emms-cache (arg) + "Turn on Emms caching if ARG is positive, off otherwise." + (interactive "p") + (if (and arg (> arg 0)) + (progn + (add-hook 'after-init-hook 'emms-cache-restore) + (add-hook 'kill-emacs-hook 'emms-cache-save) + (setq emms-cache-get-function 'emms-cache-get) + (setq emms-cache-set-function 'emms-cache-set) + (setq emms-cache-modified-function 'emms-cache-dirty)) + (remove-hook 'after-init-hook 'emms-cache-restore) + (remove-hook 'kill-emacs-hook 'emms-cache-save) + (setq emms-cache-get-function nil) + (setq emms-cache-set-function nil) + (setq emms-cache-modified-function nil))) + +;;;###autoload +(defun emms-cache-enable () + "Enable caching of Emms track data." + (interactive) + (emms-cache 1) + (message "Emms cache enabled")) + +;;;###autoload +(defun emms-cache-disable () + "Disable caching of Emms track data." + (interactive) + (emms-cache -1) + (message "Emms cache disabled")) + +;;;###autoload +(defun emms-cache-toggle () + "Toggle caching of Emms track data." + (interactive) + (if emms-cache-get-function + (emms-cache-disable) + (emms-cache-enable))) + (defun emms-cache-dirty (&rest ignored) "Mark the cache as dirty." (setq emms-cache-dirty t)) diff --git a/emms-setup.el b/emms-setup.el index b3f8313..dc55b36 100644 --- a/emms-setup.el +++ b/emms-setup.el @@ -84,11 +84,7 @@ audio files, and a metadata cache." (add-to-list 'emms-info-functions 'emms-info-mp3info) (add-to-list 'emms-info-functions 'emms-info-ogginfo) (setq emms-track-description-function 'emms-info-track-description) - (add-hook 'after-init-hook 'emms-cache-restore) - (add-hook 'kill-emacs-hook 'emms-cache-save) - (setq emms-cache-get-function 'emms-cache-get) - (setq emms-cache-set-function 'emms-cache-set) - (setq emms-cache-modified-function 'emms-cache-dirty)) + (emms-cache 1)) ;;;###autoload (defun emms-all () diff --git a/emms.el b/emms.el index f818343..e2f2fa3 100644 --- a/emms.el +++ b/emms.el @@ -222,7 +222,8 @@ This is called with two arguments, the type and the name." (defcustom emms-cache-set-function nil "A function to add/set a track entry from the cache. -This is called with a single argument, the track." +This is called with three arguments: the type of the track, the +name of the track, and the track itself." :group 'emms :type 'function) -- cgit v1.2.3