mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 00:20:25 +08:00 
			
		
		
		
	[API] Add pagination to ListBranches (#14524)
* make PaginateUserSlice generic -> PaginateSlice * Add pagination to ListBranches * add skip, limit to Repository.GetBranches() * Move routers/api/v1/utils/utils PaginateSlice -> modules/util/paginate.go * repo_module.GetBranches paginate * fix & rename & more logging * better description Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: a1012112796 <1012112796@qq.com>
This commit is contained in:
		@@ -13,6 +13,9 @@ import (
 | 
			
		||||
 | 
			
		||||
// GetBranch returns a branch by its name
 | 
			
		||||
func GetBranch(repo *models.Repository, branch string) (*git.Branch, error) {
 | 
			
		||||
	if len(branch) == 0 {
 | 
			
		||||
		return nil, fmt.Errorf("GetBranch: empty string for branch")
 | 
			
		||||
	}
 | 
			
		||||
	gitRepo, err := git.OpenRepository(repo.RepoPath())
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
@@ -22,9 +25,10 @@ func GetBranch(repo *models.Repository, branch string) (*git.Branch, error) {
 | 
			
		||||
	return gitRepo.GetBranch(branch)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// GetBranches returns all the branches of a repository
 | 
			
		||||
func GetBranches(repo *models.Repository) ([]*git.Branch, error) {
 | 
			
		||||
	return git.GetBranchesByPath(repo.RepoPath())
 | 
			
		||||
// GetBranches returns branches from the repository, skipping skip initial branches and
 | 
			
		||||
// returning at most limit branches, or all branches if limit is 0.
 | 
			
		||||
func GetBranches(repo *models.Repository, skip, limit int) ([]*git.Branch, int, error) {
 | 
			
		||||
	return git.GetBranchesByPath(repo.RepoPath(), skip, limit)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// checkBranchName validates branch name with existing repository branches
 | 
			
		||||
@@ -35,7 +39,7 @@ func checkBranchName(repo *models.Repository, name string) error {
 | 
			
		||||
	}
 | 
			
		||||
	defer gitRepo.Close()
 | 
			
		||||
 | 
			
		||||
	branches, err := GetBranches(repo)
 | 
			
		||||
	branches, _, err := GetBranches(repo, 0, 0)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
@@ -239,7 +239,7 @@ func adoptRepository(ctx models.DBContext, repoPath string, u *models.User, repo
 | 
			
		||||
 | 
			
		||||
		repo.DefaultBranch = strings.TrimPrefix(repo.DefaultBranch, git.BranchPrefix)
 | 
			
		||||
	}
 | 
			
		||||
	branches, _ := gitRepo.GetBranches()
 | 
			
		||||
	branches, _, _ := gitRepo.GetBranches(0, 0)
 | 
			
		||||
	found := false
 | 
			
		||||
	hasDefault := false
 | 
			
		||||
	hasMaster := false
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user