store: Memoize 'add-to-store' based on the result of 'lstat', not 'stat'.

* guix/store.scm (add-to-store): Change 'stat' call to 'lstat'.  Clarify
  docstring.
This commit is contained in:
Ludovic Courtès 2015-06-19 10:17:37 +02:00
parent 020f3e4156
commit 69792b285c

View File

@ -610,11 +610,12 @@ path."
store-path))) store-path)))
(lambda (server basename recursive? hash-algo file-name) (lambda (server basename recursive? hash-algo file-name)
"Add the contents of FILE-NAME under BASENAME to the store. When "Add the contents of FILE-NAME under BASENAME to the store. When
RECURSIVE? is true and FILE-NAME designates a directory, the contents of RECURSIVE? is false, FILE-NAME must designate a regular file--not a directory
FILE-NAME are added recursively; if FILE-NAME designates a flat file and nor a symlink. When RECURSIVE? is true and FILE-NAME designates a directory,
RECURSIVE? is true, its contents are added, and its permission bits are the contents of FILE-NAME are added recursively; if FILE-NAME designates a
kept. HASH-ALGO must be a string such as \"sha256\"." flat file and RECURSIVE? is true, its contents are added, and its permission
(let* ((st (stat file-name #f)) bits are kept. HASH-ALGO must be a string such as \"sha256\"."
(let* ((st (false-if-exception (lstat file-name)))
(args `(,st ,basename ,recursive? ,hash-algo)) (args `(,st ,basename ,recursive? ,hash-algo))
(cache (nix-server-add-to-store-cache server))) (cache (nix-server-add-to-store-cache server)))
(or (and st (hash-ref cache args)) (or (and st (hash-ref cache args))