diff options
author | Sean Allred <code@seanallred.com> | 2014-11-14 22:03:31 -0500 |
---|---|---|
committer | Sean Allred <code@seanallred.com> | 2014-11-14 22:03:31 -0500 |
commit | 6733365df0eb86eff433a9c8f80b32832c426e53 (patch) | |
tree | a8091b37b285e3281511da306e96b94b1742778d /sx-cache.el | |
parent | 3cb483821a9c7e852324af224b93dca4bd855b03 (diff) | |
parent | 7881572c09281785c1d0303d13305b583b3803cd (diff) |
Merge pull request #53 from vermiculus/network-list
Smart caching
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. |