diff options
author | Ethan Koenig <etk39@cornell.edu> | 2017-06-20 01:05:32 -0400 |
---|---|---|
committer | Lunny Xiao <xiaolunwen@gmail.com> | 2017-06-20 13:05:32 +0800 |
commit | 75f166b6b9dc51d48b94006e82051c41247605ab (patch) | |
tree | 8996c7f20f2d9daff2ea832c6b9548225b1d3065 /vendor/code.gitea.io/git | |
parent | 165cf337714769ab79c5fe845f291e56c8243475 (diff) | |
download | gitea-75f166b6b9dc51d48b94006e82051c41247605ab.tar.gz gitea-75f166b6b9dc51d48b94006e82051c41247605ab.zip |
Update code.gitea.io/git (#2014)
Diffstat (limited to 'vendor/code.gitea.io/git')
-rw-r--r-- | vendor/code.gitea.io/git/tree_entry.go | 47 |
1 files changed, 25 insertions, 22 deletions
diff --git a/vendor/code.gitea.io/git/tree_entry.go b/vendor/code.gitea.io/git/tree_entry.go index f3b0603456..4c69002f4f 100644 --- a/vendor/code.gitea.io/git/tree_entry.go +++ b/vendor/code.gitea.io/git/tree_entry.go @@ -6,8 +6,7 @@ package git import ( "fmt" - "os" - "path/filepath" + "path" "sort" "strconv" "strings" @@ -149,7 +148,7 @@ func (tes Entries) Sort() { // getCommitInfoState transient state for getting commit info for entries type getCommitInfoState struct { entries map[string]*TreeEntry // map from filepath to entry - commits map[string]*Commit // map from entry name to commit + commits map[string]*Commit // map from filepath to commit lastCommitHash string lastCommit *Commit treePath string @@ -160,7 +159,10 @@ type getCommitInfoState struct { func initGetCommitInfoState(entries Entries, headCommit *Commit, treePath string) *getCommitInfoState { entriesByPath := make(map[string]*TreeEntry, len(entries)) for _, entry := range entries { - entriesByPath[filepath.Join(treePath, entry.Name())] = entry + entriesByPath[path.Join(treePath, entry.Name())] = entry + } + if treePath = path.Clean(treePath); treePath == "." { + treePath = "" } return &getCommitInfoState{ entries: entriesByPath, @@ -180,7 +182,7 @@ func (tes Entries) GetCommitsInfo(commit *Commit, treePath string) ([][]interfac commitsInfo := make([][]interface{}, len(tes)) for i, entry := range tes { - commit = state.commits[filepath.Join(treePath, entry.Name())] + commit = state.commits[path.Join(treePath, entry.Name())] switch entry.Type { case ObjectCommit: subModuleURL := "" @@ -211,22 +213,23 @@ func (state *getCommitInfoState) commit() (*Commit, error) { return state.lastCommit, err } -func (state *getCommitInfoState) update(path string) error { - relPath, err := filepath.Rel(state.treePath, path) - if err != nil { - return nil +func (state *getCommitInfoState) update(entryPath string) error { + var entryNameStartIndex int + if len(state.treePath) > 0 { + entryNameStartIndex = len(state.treePath) + 1 } - var entryPath string - if index := strings.IndexRune(relPath, os.PathSeparator); index >= 0 { - entryPath = filepath.Join(state.treePath, relPath[:index]) - } else { - entryPath = path + + if index := strings.IndexByte(entryPath[entryNameStartIndex:], '/'); index >= 0 { + entryPath = entryPath[:entryNameStartIndex+index] } + if _, ok := state.entries[entryPath]; !ok { return nil } else if _, ok := state.commits[entryPath]; ok { return nil } + + var err error state.commits[entryPath], err = state.commit() return err } @@ -251,17 +254,17 @@ func getNextCommitInfos(state *getCommitInfoState) error { state.nextCommit(lines[i]) i++ for ; i < len(lines); i++ { - path := lines[i] - if path == "" { + entryPath := lines[i] + if entryPath == "" { break } - if path[0] == '"' { - path, err = strconv.Unquote(path) + if entryPath[0] == '"' { + entryPath, err = strconv.Unquote(entryPath) if err != nil { return fmt.Errorf("Unquote: %v", err) } } - state.update(path) + state.update(entryPath) } i++ // skip blank line if len(state.entries) == len(state.commits) { @@ -284,9 +287,9 @@ func logCommand(exclusiveStartHash string, state *getCommitInfoState) *Command { searchSize := (numRemainingEntries + 1) / 2 command = NewCommand("log", prettyLogFormat, "--name-only", "-"+strconv.Itoa(searchSize), commitHash, "--") - for path, entry := range state.entries { - if _, ok := state.commits[entry.Name()]; !ok { - command.AddArguments(path) + for entryPath := range state.entries { + if _, ok := state.commits[entryPath]; !ok { + command.AddArguments(entryPath) } } } else { |