summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--guix/git.scm12
1 files changed, 10 insertions, 2 deletions
diff --git a/guix/git.scm b/guix/git.scm
index da0a668587..9975c9b92e 100644
--- a/guix/git.scm
+++ b/guix/git.scm
@@ -556,7 +556,7 @@ values: the cache directory name, and the SHA1 commit (a string) corresponding
to REF, and the relation of STARTING-COMMIT relative to the new commit (if
provided) as returned by 'commit-relation'.
-REF is pair whose key is [branch | commit | tag | tag-or-commit ] and value
+REF is pair whose key is [branch | commit | symref | tag | tag-or-commit ] and value
the associated data: [<branch name> | <sha1> | <tag name> | <string>].
If REF is the empty list, the remote HEAD is used.
@@ -592,6 +592,11 @@ current settings unchanged."
(string-append "origin/" branch))))
(_ ref)))
+ (define symref-list
+ (match ref
+ (('symref . symref) (list symref))
+ (_ '())))
+
(with-libgit2
(set-git-timeouts connection-timeout read-timeout)
(let* ((cache-exists? (openable-repository? cache-directory))
@@ -606,7 +611,10 @@ current settings unchanged."
(remote-fetch (remote-lookup repository "origin")
#:fetch-options (make-default-fetch-options
#:verify-certificate?
- verify-certificate?)))
+ verify-certificate?)
+ ;; Symbolic references are not fetched from the remote by
+ ;; default.
+ #:refspecs symref-list))
(when recursive?
(update-submodules repository #:log-port log-port
#:fetch-options