mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-02 20:06:06 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			97 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2024 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package gitrepo
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
	"errors"
 | 
						|
	"strings"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/modules/git"
 | 
						|
	"code.gitea.io/gitea/modules/git/gitcmd"
 | 
						|
)
 | 
						|
 | 
						|
// GetBranchesByPath returns a branch by its path
 | 
						|
// if limit = 0 it will not limit
 | 
						|
func GetBranchesByPath(ctx context.Context, repo Repository, skip, limit int) ([]string, int, error) {
 | 
						|
	gitRepo, err := OpenRepository(ctx, repo)
 | 
						|
	if err != nil {
 | 
						|
		return nil, 0, err
 | 
						|
	}
 | 
						|
	defer gitRepo.Close()
 | 
						|
 | 
						|
	return gitRepo.GetBranchNames(skip, limit)
 | 
						|
}
 | 
						|
 | 
						|
func GetBranchCommitID(ctx context.Context, repo Repository, branch string) (string, error) {
 | 
						|
	gitRepo, err := OpenRepository(ctx, repo)
 | 
						|
	if err != nil {
 | 
						|
		return "", err
 | 
						|
	}
 | 
						|
	defer gitRepo.Close()
 | 
						|
 | 
						|
	return gitRepo.GetBranchCommitID(branch)
 | 
						|
}
 | 
						|
 | 
						|
// SetDefaultBranch sets default branch of repository.
 | 
						|
func SetDefaultBranch(ctx context.Context, repo Repository, name string) error {
 | 
						|
	_, err := runCmdString(ctx, repo, gitcmd.NewCommand("symbolic-ref", "HEAD").
 | 
						|
		AddDynamicArguments(git.BranchPrefix+name))
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// GetDefaultBranch gets default branch of repository.
 | 
						|
func GetDefaultBranch(ctx context.Context, repo Repository) (string, error) {
 | 
						|
	stdout, err := runCmdString(ctx, repo, gitcmd.NewCommand("symbolic-ref", "HEAD"))
 | 
						|
	if err != nil {
 | 
						|
		return "", err
 | 
						|
	}
 | 
						|
	stdout = strings.TrimSpace(stdout)
 | 
						|
	if !strings.HasPrefix(stdout, git.BranchPrefix) {
 | 
						|
		return "", errors.New("the HEAD is not a branch: " + stdout)
 | 
						|
	}
 | 
						|
	return strings.TrimPrefix(stdout, git.BranchPrefix), nil
 | 
						|
}
 | 
						|
 | 
						|
// IsReferenceExist returns true if given reference exists in the repository.
 | 
						|
func IsReferenceExist(ctx context.Context, repo Repository, name string) bool {
 | 
						|
	_, err := runCmdString(ctx, repo, gitcmd.NewCommand("show-ref", "--verify").AddDashesAndList(name))
 | 
						|
	return err == nil
 | 
						|
}
 | 
						|
 | 
						|
// IsBranchExist returns true if given branch exists in the repository.
 | 
						|
func IsBranchExist(ctx context.Context, repo Repository, name string) bool {
 | 
						|
	return IsReferenceExist(ctx, repo, git.BranchPrefix+name)
 | 
						|
}
 | 
						|
 | 
						|
// DeleteBranch delete a branch by name on repository.
 | 
						|
func DeleteBranch(ctx context.Context, repo Repository, name string, force bool) error {
 | 
						|
	cmd := gitcmd.NewCommand("branch")
 | 
						|
 | 
						|
	if force {
 | 
						|
		cmd.AddArguments("-D")
 | 
						|
	} else {
 | 
						|
		cmd.AddArguments("-d")
 | 
						|
	}
 | 
						|
 | 
						|
	cmd.AddDashesAndList(name)
 | 
						|
	_, err := runCmdString(ctx, repo, cmd)
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// CreateBranch create a new branch
 | 
						|
func CreateBranch(ctx context.Context, repo Repository, branch, oldbranchOrCommit string) error {
 | 
						|
	cmd := gitcmd.NewCommand("branch")
 | 
						|
	cmd.AddDashesAndList(branch, oldbranchOrCommit)
 | 
						|
 | 
						|
	_, err := runCmdString(ctx, repo, cmd)
 | 
						|
	return err
 | 
						|
}
 | 
						|
 | 
						|
// RenameBranch rename a branch
 | 
						|
func RenameBranch(ctx context.Context, repo Repository, from, to string) error {
 | 
						|
	_, err := runCmdString(ctx, repo, gitcmd.NewCommand("branch", "-m").AddDynamicArguments(from, to))
 | 
						|
	return err
 | 
						|
}
 |