|  | @@ -407,12 +407,10 @@ var (
 | 
											
												
													
														|  |  // RepoFile represents a file object in git repository.
 |  |  // RepoFile represents a file object in git repository.
 | 
											
												
													
														|  |  type RepoFile struct {
 |  |  type RepoFile struct {
 | 
											
												
													
														|  |  	*git.TreeEntry
 |  |  	*git.TreeEntry
 | 
											
												
													
														|  | -	Path       string
 |  | 
 | 
											
												
													
														|  | -	Message    string
 |  | 
 | 
											
												
													
														|  | -	Created    time.Time
 |  | 
 | 
											
												
													
														|  | -	Size       int64
 |  | 
 | 
											
												
													
														|  | -	Repo       *git.Repository
 |  | 
 | 
											
												
													
														|  | -	LastCommit string
 |  | 
 | 
											
												
													
														|  | 
 |  | +	Path   string
 | 
											
												
													
														|  | 
 |  | +	Size   int64
 | 
											
												
													
														|  | 
 |  | +	Repo   *git.Repository
 | 
											
												
													
														|  | 
 |  | +	Commit *git.Commit
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // LookupBlob returns the content of an object.
 |  |  // LookupBlob returns the content of an object.
 | 
											
										
											
												
													
														|  | @@ -444,32 +442,28 @@ func GetBranches(userName, reposName string) ([]string, error) {
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // GetReposFiles returns a list of file object in given directory of repository.
 |  |  // GetReposFiles returns a list of file object in given directory of repository.
 | 
											
												
													
														|  | -func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile, error) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func GetReposFiles(userName, reposName, branchName, commitId, rpath string) ([]*RepoFile, error) {
 | 
											
												
													
														|  |  	repo, err := git.OpenRepository(RepoPath(userName, reposName))
 |  |  	repo, err := git.OpenRepository(RepoPath(userName, reposName))
 | 
											
												
													
														|  |  	if err != nil {
 |  |  	if err != nil {
 | 
											
												
													
														|  |  		return nil, err
 |  |  		return nil, err
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -	ref, err := repo.LookupReference("refs/heads/" + branchName)
 |  | 
 | 
											
												
													
														|  | -	if err != nil {
 |  | 
 | 
											
												
													
														|  | -		return nil, err
 |  | 
 | 
											
												
													
														|  | -	}
 |  | 
 | 
											
												
													
														|  | -
 |  | 
 | 
											
												
													
														|  | -	lastCommit, err := repo.LookupCommit(ref.Oid)
 |  | 
 | 
											
												
													
														|  | 
 |  | +	commit, err := GetCommit(userName, reposName, branchName, commitId)
 | 
											
												
													
														|  |  	if err != nil {
 |  |  	if err != nil {
 | 
											
												
													
														|  |  		return nil, err
 |  |  		return nil, err
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	var repodirs []*RepoFile
 |  |  	var repodirs []*RepoFile
 | 
											
												
													
														|  |  	var repofiles []*RepoFile
 |  |  	var repofiles []*RepoFile
 | 
											
												
													
														|  | -	lastCommit.Tree.Walk(func(dirname string, entry *git.TreeEntry) int {
 |  | 
 | 
											
												
													
														|  | 
 |  | +	commit.Tree.Walk(func(dirname string, entry *git.TreeEntry) int {
 | 
											
												
													
														|  |  		if dirname == rpath {
 |  |  		if dirname == rpath {
 | 
											
												
													
														|  | 
 |  | +			// TODO: size get method shoule be improved
 | 
											
												
													
														|  |  			size, err := repo.ObjectSize(entry.Id)
 |  |  			size, err := repo.ObjectSize(entry.Id)
 | 
											
												
													
														|  |  			if err != nil {
 |  |  			if err != nil {
 | 
											
												
													
														|  |  				return 0
 |  |  				return 0
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -			var cm = lastCommit
 |  | 
 | 
											
												
													
														|  | 
 |  | +			var cm = commit
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  			for {
 |  |  			for {
 | 
											
												
													
														|  |  				if cm.ParentCount() == 0 {
 |  |  				if cm.ParentCount() == 0 {
 | 
											
										
											
												
													
														|  | @@ -524,11 +518,9 @@ func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile,
 | 
											
												
													
														|  |  			rp := &RepoFile{
 |  |  			rp := &RepoFile{
 | 
											
												
													
														|  |  				entry,
 |  |  				entry,
 | 
											
												
													
														|  |  				path.Join(dirname, entry.Name),
 |  |  				path.Join(dirname, entry.Name),
 | 
											
												
													
														|  | -				cm.Message(),
 |  | 
 | 
											
												
													
														|  | -				cm.Committer.When,
 |  | 
 | 
											
												
													
														|  |  				size,
 |  |  				size,
 | 
											
												
													
														|  |  				repo,
 |  |  				repo,
 | 
											
												
													
														|  | -				cm.Id().String(),
 |  | 
 | 
											
												
													
														|  | 
 |  | +				cm,
 | 
											
												
													
														|  |  			}
 |  |  			}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  			if entry.IsFile() {
 |  |  			if entry.IsFile() {
 | 
											
										
											
												
													
														|  | @@ -543,12 +535,23 @@ func GetReposFiles(userName, reposName, branchName, rpath string) ([]*RepoFile,
 | 
											
												
													
														|  |  	return append(repodirs, repofiles...), nil
 |  |  	return append(repodirs, repofiles...), nil
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -// GetLastestCommit returns the latest commit of given repository.
 |  | 
 | 
											
												
													
														|  | -func GetLastCommit(userName, repoName, branchname string) (*git.Commit, error) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +func GetCommit(userName, repoName, branchname, commitid string) (*git.Commit, error) {
 | 
											
												
													
														|  |  	repo, err := git.OpenRepository(RepoPath(userName, repoName))
 |  |  	repo, err := git.OpenRepository(RepoPath(userName, repoName))
 | 
											
												
													
														|  |  	if err != nil {
 |  |  	if err != nil {
 | 
											
												
													
														|  |  		return nil, err
 |  |  		return nil, err
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if commitid != "" {
 | 
											
												
													
														|  | 
 |  | +		oid, err := git.NewOidFromString(commitid)
 | 
											
												
													
														|  | 
 |  | +		if err != nil {
 | 
											
												
													
														|  | 
 |  | +			return nil, err
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  | 
 |  | +		return repo.LookupCommit(oid)
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +	if branchname == "" {
 | 
											
												
													
														|  | 
 |  | +		return nil, errors.New("no branch name and no commit id")
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	r, err := repo.LookupReference(fmt.Sprintf("refs/heads/%s", branchname))
 |  |  	r, err := repo.LookupReference(fmt.Sprintf("refs/heads/%s", branchname))
 | 
											
												
													
														|  |  	if err != nil {
 |  |  	if err != nil {
 | 
											
												
													
														|  |  		return nil, err
 |  |  		return nil, err
 |