Util type to parse ref name (#21969)

Provide a new type to make it easier to parse a ref name.

Actually, it's picked up from #21937, to make the origin PR lighter.

Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
forgejo
Jason Song 2 years ago committed by GitHub
parent 4e5d4d0073
commit f9cbf5a1bc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -55,40 +55,57 @@ func (ref *Reference) Commit() (*Commit, error) {
// ShortName returns the short name of the reference // ShortName returns the short name of the reference
func (ref *Reference) ShortName() string { func (ref *Reference) ShortName() string {
if ref == nil { return RefName(ref.Name).ShortName()
return "" }
}
if strings.HasPrefix(ref.Name, BranchPrefix) { // RefGroup returns the group type of the reference
return strings.TrimPrefix(ref.Name, BranchPrefix) func (ref *Reference) RefGroup() string {
return RefName(ref.Name).RefGroup()
}
// RefName represents a git reference name
type RefName string
func (ref RefName) IsBranch() bool {
return strings.HasPrefix(string(ref), BranchPrefix)
}
func (ref RefName) IsTag() bool {
return strings.HasPrefix(string(ref), TagPrefix)
}
// ShortName returns the short name of the reference name
func (ref RefName) ShortName() string {
refName := string(ref)
if strings.HasPrefix(refName, BranchPrefix) {
return strings.TrimPrefix(refName, BranchPrefix)
} }
if strings.HasPrefix(ref.Name, TagPrefix) { if strings.HasPrefix(refName, TagPrefix) {
return strings.TrimPrefix(ref.Name, TagPrefix) return strings.TrimPrefix(refName, TagPrefix)
} }
if strings.HasPrefix(ref.Name, RemotePrefix) { if strings.HasPrefix(refName, RemotePrefix) {
return strings.TrimPrefix(ref.Name, RemotePrefix) return strings.TrimPrefix(refName, RemotePrefix)
} }
if strings.HasPrefix(ref.Name, PullPrefix) && strings.IndexByte(ref.Name[pullLen:], '/') > -1 { if strings.HasPrefix(refName, PullPrefix) && strings.IndexByte(refName[pullLen:], '/') > -1 {
return ref.Name[pullLen : strings.IndexByte(ref.Name[pullLen:], '/')+pullLen] return refName[pullLen : strings.IndexByte(refName[pullLen:], '/')+pullLen]
} }
return ref.Name return refName
} }
// RefGroup returns the group type of the reference // RefGroup returns the group type of the reference
func (ref *Reference) RefGroup() string { func (ref RefName) RefGroup() string {
if ref == nil { refName := string(ref)
return "" if strings.HasPrefix(refName, BranchPrefix) {
}
if strings.HasPrefix(ref.Name, BranchPrefix) {
return "heads" return "heads"
} }
if strings.HasPrefix(ref.Name, TagPrefix) { if strings.HasPrefix(refName, TagPrefix) {
return "tags" return "tags"
} }
if strings.HasPrefix(ref.Name, RemotePrefix) { if strings.HasPrefix(refName, RemotePrefix) {
return "remotes" return "remotes"
} }
if strings.HasPrefix(ref.Name, PullPrefix) && strings.IndexByte(ref.Name[pullLen:], '/') > -1 { if strings.HasPrefix(refName, PullPrefix) && strings.IndexByte(refName[pullLen:], '/') > -1 {
return "pull" return "pull"
} }
return "" return ""

Loading…
Cancel
Save