forked from gitea/gitea
		
	 8598356df1
			
		
	
	
		8598356df1
		
			
		
	
	
	
	
		
			
			The merge and update branch code was previously a little tangled and had some very long functions. The functions were not very clear in their reasoning and there were deficiencies in their logging and at least one bug in the handling of LFS for update by rebase. This PR substantially refactors this code and splits things out to into separate functions. It also attempts to tidy up the calls by wrapping things in "context"s. There are also attempts to improve logging when there are errors. Signed-off-by: Andrew Thornton <art27@cantab.net> --------- Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: techknowlogick <techknowlogick@gitea.io> Co-authored-by: delvh <dev.lh@web.de>
		
			
				
	
	
		
			26 lines
		
	
	
		
			853 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			853 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package pull
 | |
| 
 | |
| import (
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/log"
 | |
| )
 | |
| 
 | |
| // doMergeStyleMerge merges the tracking into the current HEAD - which is assumed to tbe staging branch (equal to the pr.BaseBranch)
 | |
| func doMergeStyleMerge(ctx *mergeContext, message string) error {
 | |
| 	cmd := git.NewCommand(ctx, "merge", "--no-ff", "--no-commit").AddDynamicArguments(trackingBranch)
 | |
| 	if err := runMergeCommand(ctx, repo_model.MergeStyleMerge, cmd); err != nil {
 | |
| 		log.Error("%-v Unable to merge tracking into base: %v", ctx.pr, err)
 | |
| 		return err
 | |
| 	}
 | |
| 
 | |
| 	if err := commitAndSignNoAuthor(ctx, message); err != nil {
 | |
| 		log.Error("%-v Unable to make final commit: %v", ctx.pr, err)
 | |
| 		return err
 | |
| 	}
 | |
| 	return nil
 | |
| }
 |