|
|
|
@ -400,15 +400,6 @@ func DeleteRepository(userId, repoId int64, userName string) (err error) { |
|
|
|
|
return nil |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Commit represents a git commit.
|
|
|
|
|
type Commit struct { |
|
|
|
|
Author string |
|
|
|
|
Email string |
|
|
|
|
Date time.Time |
|
|
|
|
SHA string |
|
|
|
|
Message string |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
var ( |
|
|
|
|
ErrRepoFileNotLoaded = fmt.Errorf("repo file not loaded") |
|
|
|
|
) |
|
|
|
@ -553,34 +544,16 @@ func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile, |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// GetLastestCommit returns the latest commit of given repository.
|
|
|
|
|
func GetLastestCommit(userName, repoName string) (*Commit, error) { |
|
|
|
|
stdout, _, err := com.ExecCmd("git", "--git-dir="+RepoPath(userName, repoName), "log", "-1") |
|
|
|
|
func GetLastCommit(userName, repoName, branchname string) (*git.Commit, error) { |
|
|
|
|
repo, err := git.OpenRepository(RepoPath(userName, repoName)) |
|
|
|
|
if err != nil { |
|
|
|
|
return nil, err |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
commit := new(Commit) |
|
|
|
|
for _, line := range strings.Split(stdout, "\n") { |
|
|
|
|
if len(line) == 0 { |
|
|
|
|
continue |
|
|
|
|
} |
|
|
|
|
switch { |
|
|
|
|
case line[0] == 'c': |
|
|
|
|
commit.SHA = line[7:] |
|
|
|
|
case line[0] == 'A': |
|
|
|
|
infos := strings.SplitN(line, " ", 3) |
|
|
|
|
commit.Author = infos[1] |
|
|
|
|
commit.Email = infos[2][1 : len(infos[2])-1] |
|
|
|
|
case line[0] == 'D': |
|
|
|
|
commit.Date, err = time.Parse("Mon Jan 02 15:04:05 2006 -0700", line[8:]) |
|
|
|
|
r, err := repo.LookupReference(fmt.Sprintf("refs/heads/%s", branchname)) |
|
|
|
|
if err != nil { |
|
|
|
|
return nil, err |
|
|
|
|
} |
|
|
|
|
case line[:4] == " ": |
|
|
|
|
commit.Message = line[4:] |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
return commit, nil |
|
|
|
|
return r.LastCommit() |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// GetCommits returns all commits of given branch of repository.
|
|
|
|
|