mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	Move git command to git/gitcmd (#35483)
The name cmd is already used in many places and may cause conflicts, so I chose `gitcmd` instead to minimize potential naming conflicts.
This commit is contained in:
		| @@ -17,6 +17,7 @@ import ( | ||||
| 	"strings" | ||||
| 	"time" | ||||
|  | ||||
| 	"code.gitea.io/gitea/modules/git/gitcmd" | ||||
| 	"code.gitea.io/gitea/modules/proxy" | ||||
| 	"code.gitea.io/gitea/modules/setting" | ||||
| ) | ||||
| @@ -40,9 +41,9 @@ func (repo *Repository) GetAllCommitsCount() (int64, error) { | ||||
|  | ||||
| func (repo *Repository) ShowPrettyFormatLogToList(ctx context.Context, revisionRange string) ([]*Commit, error) { | ||||
| 	// avoid: ambiguous argument 'refs/a...refs/b': unknown revision or path not in the working tree. Use '--': 'git <command> [<revision>...] -- [<file>...]' | ||||
| 	logs, _, err := NewCommand("log").AddArguments(prettyLogFormat). | ||||
| 	logs, _, err := gitcmd.NewCommand("log").AddArguments(prettyLogFormat). | ||||
| 		AddDynamicArguments(revisionRange).AddArguments("--"). | ||||
| 		RunStdBytes(ctx, &RunOpts{Dir: repo.Path}) | ||||
| 		RunStdBytes(ctx, &gitcmd.RunOpts{Dir: repo.Path}) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @@ -70,7 +71,7 @@ func (repo *Repository) parsePrettyFormatLogToList(logs []byte) ([]*Commit, erro | ||||
|  | ||||
| // IsRepoURLAccessible checks if given repository URL is accessible. | ||||
| func IsRepoURLAccessible(ctx context.Context, url string) bool { | ||||
| 	_, _, err := NewCommand("ls-remote", "-q", "-h").AddDynamicArguments(url, "HEAD").RunStdString(ctx, nil) | ||||
| 	_, _, err := gitcmd.NewCommand("ls-remote", "-q", "-h").AddDynamicArguments(url, "HEAD").RunStdString(ctx, nil) | ||||
| 	return err == nil | ||||
| } | ||||
|  | ||||
| @@ -81,7 +82,7 @@ func InitRepository(ctx context.Context, repoPath string, bare bool, objectForma | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	cmd := NewCommand("init") | ||||
| 	cmd := gitcmd.NewCommand("init") | ||||
|  | ||||
| 	if !IsValidObjectFormat(objectFormatName) { | ||||
| 		return fmt.Errorf("invalid object format: %s", objectFormatName) | ||||
| @@ -93,15 +94,15 @@ func InitRepository(ctx context.Context, repoPath string, bare bool, objectForma | ||||
| 	if bare { | ||||
| 		cmd.AddArguments("--bare") | ||||
| 	} | ||||
| 	_, _, err = cmd.RunStdString(ctx, &RunOpts{Dir: repoPath}) | ||||
| 	_, _, err = cmd.RunStdString(ctx, &gitcmd.RunOpts{Dir: repoPath}) | ||||
| 	return err | ||||
| } | ||||
|  | ||||
| // IsEmpty Check if repository is empty. | ||||
| func (repo *Repository) IsEmpty() (bool, error) { | ||||
| 	var errbuf, output strings.Builder | ||||
| 	if err := NewCommand().AddOptionFormat("--git-dir=%s", repo.Path).AddArguments("rev-list", "-n", "1", "--all"). | ||||
| 		Run(repo.Ctx, &RunOpts{ | ||||
| 	if err := gitcmd.NewCommand().AddOptionFormat("--git-dir=%s", repo.Path).AddArguments("rev-list", "-n", "1", "--all"). | ||||
| 		Run(repo.Ctx, &gitcmd.RunOpts{ | ||||
| 			Dir:    repo.Path, | ||||
| 			Stdout: &output, | ||||
| 			Stderr: &errbuf, | ||||
| @@ -137,7 +138,7 @@ func Clone(ctx context.Context, from, to string, opts CloneRepoOptions) error { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	cmd := NewCommand().AddArguments("clone") | ||||
| 	cmd := gitcmd.NewCommand().AddArguments("clone") | ||||
| 	if opts.SkipTLSVerify { | ||||
| 		cmd.AddArguments("-c", "http.sslVerify=false") | ||||
| 	} | ||||
| @@ -178,13 +179,13 @@ func Clone(ctx context.Context, from, to string, opts CloneRepoOptions) error { | ||||
| 	} | ||||
|  | ||||
| 	stderr := new(bytes.Buffer) | ||||
| 	if err = cmd.Run(ctx, &RunOpts{ | ||||
| 	if err = cmd.Run(ctx, &gitcmd.RunOpts{ | ||||
| 		Timeout: opts.Timeout, | ||||
| 		Env:     envs, | ||||
| 		Stdout:  io.Discard, | ||||
| 		Stderr:  stderr, | ||||
| 	}); err != nil { | ||||
| 		return ConcatenateError(err, stderr.String()) | ||||
| 		return gitcmd.ConcatenateError(err, stderr.String()) | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
| @@ -201,7 +202,7 @@ type PushOptions struct { | ||||
|  | ||||
| // Push pushs local commits to given remote branch. | ||||
| func Push(ctx context.Context, repoPath string, opts PushOptions) error { | ||||
| 	cmd := NewCommand("push") | ||||
| 	cmd := gitcmd.NewCommand("push") | ||||
| 	if opts.Force { | ||||
| 		cmd.AddArguments("-f") | ||||
| 	} | ||||
| @@ -214,7 +215,7 @@ func Push(ctx context.Context, repoPath string, opts PushOptions) error { | ||||
| 	} | ||||
| 	cmd.AddDashesAndList(remoteBranchArgs...) | ||||
|  | ||||
| 	stdout, stderr, err := cmd.RunStdString(ctx, &RunOpts{Env: opts.Env, Timeout: opts.Timeout, Dir: repoPath}) | ||||
| 	stdout, stderr, err := cmd.RunStdString(ctx, &gitcmd.RunOpts{Env: opts.Env, Timeout: opts.Timeout, Dir: repoPath}) | ||||
| 	if err != nil { | ||||
| 		if strings.Contains(stderr, "non-fast-forward") { | ||||
| 			return &ErrPushOutOfDate{StdOut: stdout, StdErr: stderr, Err: err} | ||||
| @@ -233,8 +234,8 @@ func Push(ctx context.Context, repoPath string, opts PushOptions) error { | ||||
|  | ||||
| // GetLatestCommitTime returns time for latest commit in repository (across all branches) | ||||
| func GetLatestCommitTime(ctx context.Context, repoPath string) (time.Time, error) { | ||||
| 	cmd := NewCommand("for-each-ref", "--sort=-committerdate", BranchPrefix, "--count", "1", "--format=%(committerdate)") | ||||
| 	stdout, _, err := cmd.RunStdString(ctx, &RunOpts{Dir: repoPath}) | ||||
| 	cmd := gitcmd.NewCommand("for-each-ref", "--sort=-committerdate", BranchPrefix, "--count", "1", "--format=%(committerdate)") | ||||
| 	stdout, _, err := cmd.RunStdString(ctx, &gitcmd.RunOpts{Dir: repoPath}) | ||||
| 	if err != nil { | ||||
| 		return time.Time{}, err | ||||
| 	} | ||||
| @@ -250,9 +251,9 @@ type DivergeObject struct { | ||||
|  | ||||
| // GetDivergingCommits returns the number of commits a targetBranch is ahead or behind a baseBranch | ||||
| func GetDivergingCommits(ctx context.Context, repoPath, baseBranch, targetBranch string) (do DivergeObject, err error) { | ||||
| 	cmd := NewCommand("rev-list", "--count", "--left-right"). | ||||
| 	cmd := gitcmd.NewCommand("rev-list", "--count", "--left-right"). | ||||
| 		AddDynamicArguments(baseBranch + "..." + targetBranch).AddArguments("--") | ||||
| 	stdout, _, err := cmd.RunStdString(ctx, &RunOpts{Dir: repoPath}) | ||||
| 	stdout, _, err := cmd.RunStdString(ctx, &gitcmd.RunOpts{Dir: repoPath}) | ||||
| 	if err != nil { | ||||
| 		return do, err | ||||
| 	} | ||||
| @@ -281,23 +282,23 @@ func (repo *Repository) CreateBundle(ctx context.Context, commit string, out io. | ||||
| 	defer cleanup() | ||||
|  | ||||
| 	env := append(os.Environ(), "GIT_OBJECT_DIRECTORY="+filepath.Join(repo.Path, "objects")) | ||||
| 	_, _, err = NewCommand("init", "--bare").RunStdString(ctx, &RunOpts{Dir: tmp, Env: env}) | ||||
| 	_, _, err = gitcmd.NewCommand("init", "--bare").RunStdString(ctx, &gitcmd.RunOpts{Dir: tmp, Env: env}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	_, _, err = NewCommand("reset", "--soft").AddDynamicArguments(commit).RunStdString(ctx, &RunOpts{Dir: tmp, Env: env}) | ||||
| 	_, _, err = gitcmd.NewCommand("reset", "--soft").AddDynamicArguments(commit).RunStdString(ctx, &gitcmd.RunOpts{Dir: tmp, Env: env}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	_, _, err = NewCommand("branch", "-m", "bundle").RunStdString(ctx, &RunOpts{Dir: tmp, Env: env}) | ||||
| 	_, _, err = gitcmd.NewCommand("branch", "-m", "bundle").RunStdString(ctx, &gitcmd.RunOpts{Dir: tmp, Env: env}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| 	tmpFile := filepath.Join(tmp, "bundle") | ||||
| 	_, _, err = NewCommand("bundle", "create").AddDynamicArguments(tmpFile, "bundle", "HEAD").RunStdString(ctx, &RunOpts{Dir: tmp, Env: env}) | ||||
| 	_, _, err = gitcmd.NewCommand("bundle", "create").AddDynamicArguments(tmpFile, "bundle", "HEAD").RunStdString(ctx, &gitcmd.RunOpts{Dir: tmp, Env: env}) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user