mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 22:16:32 +01:00
git: Call 'url-cache-directory' outside 'update-cached-checkout'.
* guix/git.scm (update-cached-checkout): Call 'url-cache-directory' in 'cache-directory' key argument. (latest-repository-commit): Call 'url-cache-directory'.
This commit is contained in:
parent
e29067d22e
commit
ffc3fcade3
1 changed files with 14 additions and 12 deletions
26
guix/git.scm
26
guix/git.scm
|
@ -114,7 +114,8 @@ (define* (update-cached-checkout url
|
|||
#:key
|
||||
(ref '(branch . "origin/master"))
|
||||
(cache-directory
|
||||
(%repository-cache-directory)))
|
||||
(url-cache-directory
|
||||
url (%repository-cache-directory))))
|
||||
"Update the cached checkout of URL to REF in CACHE-DIRECTORY. Return two
|
||||
values: the cache directory name, and the SHA1 commit (a string) corresponding
|
||||
to REF.
|
||||
|
@ -122,11 +123,10 @@ (define* (update-cached-checkout url
|
|||
REF is pair whose key is [branch | commit | tag] and value the associated
|
||||
data, respectively [<branch name> | <sha1> | <tag name>]."
|
||||
(with-libgit2
|
||||
(let* ((cache-dir (url-cache-directory url cache-directory))
|
||||
(cache-exists? (openable-repository? cache-dir))
|
||||
(let* ((cache-exists? (openable-repository? cache-directory))
|
||||
(repository (if cache-exists?
|
||||
(repository-open cache-dir)
|
||||
(clone* url cache-dir))))
|
||||
(repository-open cache-directory)
|
||||
(clone* url cache-directory))))
|
||||
;; Only fetch remote if it has not been cloned just before.
|
||||
(when cache-exists?
|
||||
(remote-fetch (remote-lookup repository "origin")))
|
||||
|
@ -138,7 +138,7 @@ (define* (update-cached-checkout url
|
|||
'repository-close!)
|
||||
(repository-close! repository))
|
||||
|
||||
(values cache-dir (oid->string oid))))))
|
||||
(values cache-directory (oid->string oid))))))
|
||||
|
||||
(define* (latest-repository-commit store url
|
||||
#:key
|
||||
|
@ -157,12 +157,14 @@ (define (dot-git? file stat)
|
|||
(and (string=? (basename file) ".git")
|
||||
(eq? 'directory (stat:type stat))))
|
||||
|
||||
(let*-values (((checkout commit)
|
||||
(update-cached-checkout url
|
||||
#:ref ref
|
||||
#:cache-directory cache-directory))
|
||||
((name)
|
||||
(url+commit->name url commit)))
|
||||
(let*-values
|
||||
(((checkout commit)
|
||||
(update-cached-checkout url
|
||||
#:ref ref
|
||||
#:cache-directory
|
||||
(url-cache-directory url cache-directory)))
|
||||
((name)
|
||||
(url+commit->name url commit)))
|
||||
(values (add-to-store store name #t "sha256" checkout
|
||||
#:select? (negate dot-git?))
|
||||
commit)))
|
||||
|
|
Loading…
Reference in a new issue