summaryrefslogtreecommitdiffstats
path: root/vendor/code.gitea.io/git
diff options
context:
space:
mode:
authorAntoine GIRARD <sapk@sapk.fr>2017-06-06 19:36:48 +0200
committerAntoine GIRARD <sapk@sapk.fr>2017-06-06 19:36:48 +0200
commit0cf89a83c111fe49a8be48c46873182479260d8e (patch)
tree708898b638037c998d017bdefbaf0f51d201a0bc /vendor/code.gitea.io/git
parentf6b58964d70f7a66ab0ef9affc03a2320b4abd22 (diff)
downloadgitea-0cf89a83c111fe49a8be48c46873182479260d8e.tar.gz
gitea-0cf89a83c111fe49a8be48c46873182479260d8e.zip
Update code.gitea.io/git
Diffstat (limited to 'vendor/code.gitea.io/git')
-rw-r--r--vendor/code.gitea.io/git/repo_tag.go86
-rw-r--r--vendor/code.gitea.io/git/tree_entry.go3
2 files changed, 21 insertions, 68 deletions
diff --git a/vendor/code.gitea.io/git/repo_tag.go b/vendor/code.gitea.io/git/repo_tag.go
index 4474f7862b..11f1f3da73 100644
--- a/vendor/code.gitea.io/git/repo_tag.go
+++ b/vendor/code.gitea.io/git/repo_tag.go
@@ -6,7 +6,6 @@ package git
import (
"strings"
- "time"
"github.com/mcuadros/go-version"
)
@@ -95,84 +94,37 @@ func (repo *Repository) GetTag(name string) (*Tag, error) {
return tag, nil
}
-// TagOption describes tag options
-type TagOption struct {
-}
-
-// parseTag parse the line
-// 2016-10-14 20:54:25 +0200 (tag: translation/20161014.01) d3b76dcf2 Dirk Baeumer dirkb@microsoft.com Merge in translations
-func parseTag(line string, opt TagOption) (*Tag, error) {
- line = strings.TrimSpace(line)
- if len(line) < 40 {
- return nil, nil
- }
-
- var (
- err error
- tag Tag
- sig Signature
- )
- sig.When, err = time.Parse("2006-01-02 15:04:05 -0700", line[0:25])
- if err != nil {
- return nil, err
- }
-
- left := strings.TrimSpace(line[25:])
- start := strings.Index(left, "tag: ")
- if start < 0 {
- return nil, nil
- }
- end := strings.LastIndexByte(left[start+1:], ')')
- if end < 0 {
- return nil, nil
- }
- end = end + start + 1
- part := strings.IndexByte(left[start+5:end], ',')
- if part > 0 {
- tag.Name = strings.TrimSpace(left[start+5 : start+5+part])
- } else {
- tag.Name = strings.TrimSpace(left[start+5 : end])
- }
- next := strings.IndexByte(left[end+2:], ' ')
- if next < 0 {
- return nil, nil
- }
- tag.Object = MustIDFromString(strings.TrimSpace(left[end+2 : end+2+next]))
- next = end + 2 + next
-
- emailStart := strings.IndexByte(left[next:], '<')
- sig.Name = strings.TrimSpace(left[next:][:emailStart-1])
- emailEnd := strings.IndexByte(left[next:], '>')
- sig.Email = strings.TrimSpace(left[next:][emailStart+1 : emailEnd])
- tag.Tagger = &sig
- tag.Message = strings.TrimSpace(left[next+emailEnd+1:])
- return &tag, nil
-}
-
// GetTagInfos returns all tag infos of the repository.
-func (repo *Repository) GetTagInfos(opt TagOption) ([]*Tag, error) {
- cmd := NewCommand("log", "--tags", "--simplify-by-decoration", `--pretty=format:"%ci %d %H %cn<%ce> %s"`)
- stdout, err := cmd.RunInDir(repo.Path)
+func (repo *Repository) GetTagInfos() ([]*Tag, error) {
+ // TODO this a slow implementation, makes one git command per tag
+ stdout, err := NewCommand("tag").RunInDir(repo.Path)
if err != nil {
return nil, err
}
- tagSlices := strings.Split(stdout, "\n")
+ tagNames := strings.Split(stdout, "\n")
var tags []*Tag
- for _, line := range tagSlices {
- line := strings.Trim(line, `"`)
- tag, err := parseTag(line, opt)
+ for _, tagName := range tagNames {
+ tagName = strings.TrimSpace(tagName)
+ if len(tagName) == 0 {
+ continue
+ }
+ commitID, err := NewCommand("rev-parse", tagName).RunInDir(repo.Path)
if err != nil {
return nil, err
}
- if tag != nil {
- tag.repo = repo
- tags = append(tags, tag)
+ commit, err := repo.GetCommit(commitID)
+ if err != nil {
+ return nil, err
}
+ tags = append(tags, &Tag{
+ Name: tagName,
+ Message: commit.Message(),
+ Object: commit.ID,
+ Tagger: commit.Author,
+ })
}
-
sortTagsByTime(tags)
-
return tags, nil
}
diff --git a/vendor/code.gitea.io/git/tree_entry.go b/vendor/code.gitea.io/git/tree_entry.go
index 7f454ab56c..079dfddd63 100644
--- a/vendor/code.gitea.io/git/tree_entry.go
+++ b/vendor/code.gitea.io/git/tree_entry.go
@@ -5,6 +5,7 @@
package git
import (
+ "os"
"path/filepath"
"sort"
"strconv"
@@ -215,7 +216,7 @@ func (state *getCommitInfoState) update(path string) error {
return nil
}
var entryPath string
- if index := strings.IndexRune(relPath, '/'); index >= 0 {
+ if index := strings.IndexRune(relPath, os.PathSeparator); index >= 0 {
entryPath = filepath.Join(state.treePath, relPath[:index])
} else {
entryPath = path