mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 00:20:25 +08:00 
			
		
		
		
	Set the default branch for repositories generated from templates (#19136)
* Set the default branch for repositories generated from templates * Allows default branch to be set through the API for repos generated from templates * Update swagger API template * Only set default branch to the one from the template if not specified * Use specified default branch if it exists while generating git commits Fix #19082 Co-authored-by: John Olheiser <john.olheiser@gmail.com> Co-authored-by: zeripath <art27@cantab.net>
This commit is contained in:
		@@ -184,7 +184,13 @@ func generateRepoCommit(ctx context.Context, repo, templateRepo, generateRepo *r
 | 
			
		||||
		return fmt.Errorf("git remote add: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return initRepoCommit(ctx, tmpDir, repo, repo.Owner, templateRepo.DefaultBranch)
 | 
			
		||||
	// set default branch based on whether it's specified in the newly generated repo or not
 | 
			
		||||
	defaultBranch := repo.DefaultBranch
 | 
			
		||||
	if strings.TrimSpace(defaultBranch) == "" {
 | 
			
		||||
		defaultBranch = templateRepo.DefaultBranch
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	return initRepoCommit(ctx, tmpDir, repo, repo.Owner, defaultBranch)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func generateGitContent(ctx context.Context, repo, templateRepo, generateRepo *repo_model.Repository) (err error) {
 | 
			
		||||
@@ -208,7 +214,11 @@ func generateGitContent(ctx context.Context, repo, templateRepo, generateRepo *r
 | 
			
		||||
		return fmt.Errorf("getRepositoryByID: %v", err)
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	repo.DefaultBranch = templateRepo.DefaultBranch
 | 
			
		||||
	// if there was no default branch supplied when generating the repo, use the default one from the template
 | 
			
		||||
	if strings.TrimSpace(repo.DefaultBranch) == "" {
 | 
			
		||||
		repo.DefaultBranch = templateRepo.DefaultBranch
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	gitRepo, err := git.OpenRepositoryCtx(ctx, repo.RepoPath())
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return fmt.Errorf("openRepository: %v", err)
 | 
			
		||||
@@ -249,6 +259,7 @@ func GenerateRepository(ctx context.Context, doer, owner *user_model.User, templ
 | 
			
		||||
		Name:          opts.Name,
 | 
			
		||||
		LowerName:     strings.ToLower(opts.Name),
 | 
			
		||||
		Description:   opts.Description,
 | 
			
		||||
		DefaultBranch: opts.DefaultBranch,
 | 
			
		||||
		IsPrivate:     opts.Private,
 | 
			
		||||
		IsEmpty:       !opts.GitContent || templateRepo.IsEmpty,
 | 
			
		||||
		IsFsckEnabled: templateRepo.IsFsckEnabled,
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user