diff options
author | Máximo Cuadros <mcuadros@gmail.com> | 2020-05-11 00:28:21 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-11 00:28:21 +0200 |
commit | 568154cab87659b31c751678c7f7dc93fedf60af (patch) | |
tree | 233f993126f9346b06979202042bd5d95ba70bf2 /config/refspec.go | |
parent | e4166c560bfa0bcdadd3197ad00365b4f1c027fb (diff) | |
parent | 8ecd388ae101a0dd88b78dc47ebfef9fe51699df (diff) | |
download | go-git-568154cab87659b31c751678c7f7dc93fedf60af.tar.gz |
Merge pull request #58 from go-git/exact-sha1
Remote.Fetch: support exact SHA1 refspecs
Diffstat (limited to 'config/refspec.go')
-rw-r--r-- | config/refspec.go | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/config/refspec.go b/config/refspec.go index 87cf2a6..4bfaa37 100644 --- a/config/refspec.go +++ b/config/refspec.go @@ -25,7 +25,7 @@ var ( // reference even if it isn’t a fast-forward. // eg.: "+refs/heads/*:refs/remotes/origin/*" // -// https://git-scm.com/book/es/v2/Git-Internals-The-Refspec +// https://git-scm.com/book/en/v2/Git-Internals-The-Refspec type RefSpec string // Validate validates the RefSpec @@ -59,6 +59,11 @@ func (s RefSpec) IsDelete() bool { return s[0] == refSpecSeparator[0] } +// IsExactSHA1 returns true if the source is a SHA1 hash. +func (s RefSpec) IsExactSHA1() bool { + return plumbing.IsHash(s.Src()) +} + // Src return the src side. func (s RefSpec) Src() string { spec := string(s) @@ -69,8 +74,8 @@ func (s RefSpec) Src() string { } else { start = 0 } - end := strings.Index(spec, refSpecSeparator) + end := strings.Index(spec, refSpecSeparator) return spec[start:end] } |