mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-26 02:01:29 +01:00 
			
		
		
		
	alternative to PR "improve code quality" (#21464)
This PR doesn't require new git version, and can be backported easily. Co-authored-by: 6543 <6543@obermui.de>
This commit is contained in:
		
							parent
							
								
									7917123209
								
							
						
					
					
						commit
						d98c5db58f
					
				| @ -95,6 +95,18 @@ func (c *Command) AddArguments(args ...string) *Command { | |||||||
| 	return c | 	return c | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // AddDynamicArguments adds new dynamic argument(s) to the command. | ||||||
|  | // If the argument is invalid (it shouldn't happen in real life), it panics to caller | ||||||
|  | func (c *Command) AddDynamicArguments(args ...string) *Command { | ||||||
|  | 	for _, arg := range args { | ||||||
|  | 		if arg != "" && arg[0] == '-' { | ||||||
|  | 			panic("invalid argument: " + arg) | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	c.args = append(c.args, args...) | ||||||
|  | 	return c | ||||||
|  | } | ||||||
|  | 
 | ||||||
| // RunOpts represents parameters to run the command. If UseContextTimeout is specified, then Timeout is ignored. | // RunOpts represents parameters to run the command. If UseContextTimeout is specified, then Timeout is ignored. | ||||||
| type RunOpts struct { | type RunOpts struct { | ||||||
| 	Env               []string | 	Env               []string | ||||||
|  | |||||||
| @ -26,4 +26,21 @@ func TestRunWithContextStd(t *testing.T) { | |||||||
| 		assert.Contains(t, err.Error(), "exit status 129 - unknown option:") | 		assert.Contains(t, err.Error(), "exit status 129 - unknown option:") | ||||||
| 		assert.Empty(t, stdout) | 		assert.Empty(t, stdout) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	assert.Panics(t, func() { | ||||||
|  | 		cmd = NewCommand(context.Background()) | ||||||
|  | 		cmd.AddDynamicArguments("-test") | ||||||
|  | 	}) | ||||||
|  | 
 | ||||||
|  | 	assert.Panics(t, func() { | ||||||
|  | 		cmd = NewCommand(context.Background()) | ||||||
|  | 		cmd.AddDynamicArguments("--test") | ||||||
|  | 	}) | ||||||
|  | 
 | ||||||
|  | 	subCmd := "version" | ||||||
|  | 	cmd = NewCommand(context.Background()).AddDynamicArguments(subCmd) // for test purpose only, the sub-command should never be dynamic for production | ||||||
|  | 	stdout, stderr, err = cmd.RunStdString(&RunOpts{}) | ||||||
|  | 	assert.NoError(t, err) | ||||||
|  | 	assert.Empty(t, stderr) | ||||||
|  | 	assert.Contains(t, stdout, "git version") | ||||||
| } | } | ||||||
|  | |||||||
| @ -166,7 +166,7 @@ func AllCommitsCount(ctx context.Context, repoPath string, hidePRRefs bool, file | |||||||
| // CommitsCountFiles returns number of total commits of until given revision. | // CommitsCountFiles returns number of total commits of until given revision. | ||||||
| func CommitsCountFiles(ctx context.Context, repoPath string, revision, relpath []string) (int64, error) { | func CommitsCountFiles(ctx context.Context, repoPath string, revision, relpath []string) (int64, error) { | ||||||
| 	cmd := NewCommand(ctx, "rev-list", "--count") | 	cmd := NewCommand(ctx, "rev-list", "--count") | ||||||
| 	cmd.AddArguments(revision...) | 	cmd.AddDynamicArguments(revision...) | ||||||
| 	if len(relpath) > 0 { | 	if len(relpath) > 0 { | ||||||
| 		cmd.AddArguments("--") | 		cmd.AddArguments("--") | ||||||
| 		cmd.AddArguments(relpath...) | 		cmd.AddArguments(relpath...) | ||||||
|  | |||||||
| @ -161,7 +161,7 @@ func (repo *Repository) searchCommits(id SHA1, opts SearchCommitsOptions) ([]*Co | |||||||
| 				// add previous arguments except for --grep and --all | 				// add previous arguments except for --grep and --all | ||||||
| 				hashCmd.AddArguments(args...) | 				hashCmd.AddArguments(args...) | ||||||
| 				// add keyword as <commit> | 				// add keyword as <commit> | ||||||
| 				hashCmd.AddArguments(v) | 				hashCmd.AddDynamicArguments(v) | ||||||
| 
 | 
 | ||||||
| 				// search with given constraints for commit matching sha hash of v | 				// search with given constraints for commit matching sha hash of v | ||||||
| 				hashMatching, _, err := hashCmd.RunStdBytes(&RunOpts{Dir: repo.Path}) | 				hashMatching, _, err := hashCmd.RunStdBytes(&RunOpts{Dir: repo.Path}) | ||||||
| @ -211,10 +211,13 @@ func (repo *Repository) CommitsByFileAndRange(revision, file string, page int) ( | |||||||
| 	}() | 	}() | ||||||
| 	go func() { | 	go func() { | ||||||
| 		stderr := strings.Builder{} | 		stderr := strings.Builder{} | ||||||
| 		err := NewCommand(repo.Ctx, "rev-list", revision, | 		gitCmd := NewCommand(repo.Ctx, "rev-list", | ||||||
| 			"--max-count="+strconv.Itoa(setting.Git.CommitsRangeSize*page), | 			"--max-count="+strconv.Itoa(setting.Git.CommitsRangeSize*page), | ||||||
| 			"--skip="+strconv.Itoa(skip), "--", file). | 			"--skip="+strconv.Itoa(skip), | ||||||
| 			Run(&RunOpts{ | 		) | ||||||
|  | 		gitCmd.AddDynamicArguments(revision) | ||||||
|  | 		gitCmd.AddArguments("--", file) | ||||||
|  | 		err := gitCmd.Run(&RunOpts{ | ||||||
| 			Dir:    repo.Path, | 			Dir:    repo.Path, | ||||||
| 			Stdout: stdoutWriter, | 			Stdout: stdoutWriter, | ||||||
| 			Stderr: &stderr, | 			Stderr: &stderr, | ||||||
|  | |||||||
| @ -61,15 +61,15 @@ func (repo *Repository) GetCodeActivityStats(fromTime time.Time, branch string) | |||||||
| 		_ = stdoutWriter.Close() | 		_ = stdoutWriter.Close() | ||||||
| 	}() | 	}() | ||||||
| 
 | 
 | ||||||
| 	args := []string{"log", "--numstat", "--no-merges", "--pretty=format:---%n%h%n%aN%n%aE%n", "--date=iso", fmt.Sprintf("--since='%s'", since)} | 	gitCmd := NewCommand(repo.Ctx, "log", "--numstat", "--no-merges", "--pretty=format:---%n%h%n%aN%n%aE%n", "--date=iso", fmt.Sprintf("--since='%s'", since)) | ||||||
| 	if len(branch) == 0 { | 	if len(branch) == 0 { | ||||||
| 		args = append(args, "--branches=*") | 		gitCmd.AddArguments("--branches=*") | ||||||
| 	} else { | 	} else { | ||||||
| 		args = append(args, "--first-parent", branch) | 		gitCmd.AddArguments("--first-parent").AddDynamicArguments(branch) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	stderr := new(strings.Builder) | 	stderr := new(strings.Builder) | ||||||
| 	err = NewCommand(repo.Ctx, args...).Run(&RunOpts{ | 	err = gitCmd.Run(&RunOpts{ | ||||||
| 		Env:    []string{}, | 		Env:    []string{}, | ||||||
| 		Dir:    repo.Path, | 		Dir:    repo.Path, | ||||||
| 		Stdout: stdoutWriter, | 		Stdout: stdoutWriter, | ||||||
|  | |||||||
| @ -24,19 +24,17 @@ func GetCommitGraph(r *git.Repository, page, maxAllowedColors int, hidePRRefs bo | |||||||
| 		page = 1 | 		page = 1 | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	args := make([]string, 0, 12+len(branches)+len(files)) | 	graphCmd := git.NewCommand(r.Ctx, "log", "--graph", "--date-order", "--decorate=full") | ||||||
| 
 |  | ||||||
| 	args = append(args, "--graph", "--date-order", "--decorate=full") |  | ||||||
| 
 | 
 | ||||||
| 	if hidePRRefs { | 	if hidePRRefs { | ||||||
| 		args = append(args, "--exclude="+git.PullPrefix+"*") | 		graphCmd.AddArguments("--exclude=" + git.PullPrefix + "*") | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if len(branches) == 0 { | 	if len(branches) == 0 { | ||||||
| 		args = append(args, "--all") | 		graphCmd.AddArguments("--all") | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	args = append(args, | 	graphCmd.AddArguments( | ||||||
| 		"-C", | 		"-C", | ||||||
| 		"-M", | 		"-M", | ||||||
| 		fmt.Sprintf("-n %d", setting.UI.GraphMaxCommitNum*page), | 		fmt.Sprintf("-n %d", setting.UI.GraphMaxCommitNum*page), | ||||||
| @ -44,15 +42,12 @@ func GetCommitGraph(r *git.Repository, page, maxAllowedColors int, hidePRRefs bo | |||||||
| 		fmt.Sprintf("--pretty=format:%s", format)) | 		fmt.Sprintf("--pretty=format:%s", format)) | ||||||
| 
 | 
 | ||||||
| 	if len(branches) > 0 { | 	if len(branches) > 0 { | ||||||
| 		args = append(args, branches...) | 		graphCmd.AddDynamicArguments(branches...) | ||||||
| 	} | 	} | ||||||
| 	args = append(args, "--") |  | ||||||
| 	if len(files) > 0 { | 	if len(files) > 0 { | ||||||
| 		args = append(args, files...) | 		graphCmd.AddArguments("--") | ||||||
|  | 		graphCmd.AddArguments(files...) | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	graphCmd := git.NewCommand(r.Ctx, "log") |  | ||||||
| 	graphCmd.AddArguments(args...) |  | ||||||
| 	graph := NewGraph() | 	graph := NewGraph() | ||||||
| 
 | 
 | ||||||
| 	stderr := new(strings.Builder) | 	stderr := new(strings.Builder) | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user