diff options
author | Sean Allred <code@seanallred.com> | 2014-11-11 12:45:06 -0500 |
---|---|---|
committer | Sean Allred <code@seanallred.com> | 2014-11-11 12:45:06 -0500 |
commit | 0cb05d17c806fb268343dcf932e355dba13cfb3c (patch) | |
tree | 17896a45651b1e221a2ae42511064603727b62b6 /sx-cache.el | |
parent | 9f679fdadce15381efba781e8561d4cdc172319c (diff) |
Convenience argument for `cache-get'
Allows for setting the cache if it does not exist.
Diffstat (limited to 'sx-cache.el')
-rw-r--r-- | sx-cache.el | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/sx-cache.el b/sx-cache.el index 098c292..e3b356b 100644 --- a/sx-cache.el +++ b/sx-cache.el @@ -38,18 +38,21 @@ (concat (symbol-name filename) ".el") sx-cache-directory)) -(defun sx-cache-get (cache) +(defun sx-cache-get (cache &optional form) "Return the data within CACHE. +If CACHE does not exist, evaluate FORM and set it to its return. + As with `sx-cache-set', CACHE is a file name within the context of `sx-cache-directory'." (unless (file-exists-p sx-cache-directory) (mkdir sx-cache-directory)) (let ((file (sx-cache-get-file-name cache))) - (when (file-exists-p file) - (with-temp-buffer - (insert-file-contents (sx-cache-get-file-name cache)) - (read (buffer-string)))))) + (if (file-exists-p file) + (with-temp-buffer + (insert-file-contents (sx-cache-get-file-name cache)) + (read (buffer-string))) + (sx-cache-set cache (eval form))))) (defun sx-cache-set (cache data) "Set the content of CACHE to DATA. |