mirror of
				https://gitea.com/gitea/tea.git
				synced 2025-10-31 01:05:26 +01:00 
			
		
		
		
	tea pulls create: detect head branch repo owner (#193)
dont print on already pushed branch more consisten error handling detect repo owner for default head branch Co-authored-by: Norwin Roosen <git@nroo.de> Reviewed-on: https://gitea.com/gitea/tea/pulls/193 Reviewed-by: 6543 <6543@noreply.gitea.io> Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com>
This commit is contained in:
		
							
								
								
									
										46
									
								
								cmd/pulls.go
									
									
									
									
									
								
							
							
						
						
									
										46
									
								
								cmd/pulls.go
									
									
									
									
									
								
							| @@ -341,13 +341,20 @@ func runPullsCreate(ctx *cli.Context) error { | |||||||
|  |  | ||||||
| 	repo, _, err := login.Client().GetRepo(ownerArg, repoArg) | 	repo, _, err := login.Client().GetRepo(ownerArg, repoArg) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		log.Fatal(err) | 		log.Fatal("could not fetch repo meta: ", err) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// open local git repo | 	// open local git repo | ||||||
| 	localRepo, err := local_git.RepoForWorkdir() | 	localRepo, err := local_git.RepoForWorkdir() | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		log.Fatal(err) | 		log.Fatal("could not open local repo: ", err) | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	// push if possible | ||||||
|  | 	log.Println("git push") | ||||||
|  | 	err = localRepo.Push(&git.PushOptions{}) | ||||||
|  | 	if err != nil && err != git.NoErrAlreadyUpToDate { | ||||||
|  | 		log.Printf("Error occurred during 'git push':\n%s\n", err.Error()) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	base := ctx.String("base") | 	base := ctx.String("base") | ||||||
| @@ -359,10 +366,35 @@ func runPullsCreate(ctx *cli.Context) error { | |||||||
| 	head := ctx.String("head") | 	head := ctx.String("head") | ||||||
| 	// default is current one | 	// default is current one | ||||||
| 	if len(head) == 0 { | 	if len(head) == 0 { | ||||||
| 		head, err = localRepo.TeaGetCurrentBranchName() | 		headBranch, err := localRepo.Head() | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			log.Fatal(err) | 			log.Fatal(err) | ||||||
| 		} | 		} | ||||||
|  | 		sha := headBranch.Hash().String() | ||||||
|  |  | ||||||
|  | 		remote, err := localRepo.TeaFindBranchRemote("", sha) | ||||||
|  | 		if err != nil { | ||||||
|  | 			return err | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		if remote == nil { | ||||||
|  | 			// if no remote branch is found for the local hash, we abort: | ||||||
|  | 			// user has probably not configured a remote for the local branch, | ||||||
|  | 			// or local branch does not represent remote state. | ||||||
|  | 			log.Fatal("no matching remote found for this branch. try git push -u <remote> <branch>") | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		branchName, err := localRepo.TeaGetCurrentBranchName() | ||||||
|  | 		if err != nil { | ||||||
|  | 			log.Fatal(err) | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		url, err := local_git.ParseURL(remote.Config().URLs[0]) | ||||||
|  | 		if err != nil { | ||||||
|  | 			log.Fatal(err) | ||||||
|  | 		} | ||||||
|  | 		owner, _ := getOwnerAndRepo(strings.TrimLeft(url.Path, "/"), "") | ||||||
|  | 		head = fmt.Sprintf("%s:%s", owner, branchName) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	title := ctx.String("title") | 	title := ctx.String("title") | ||||||
| @@ -382,12 +414,6 @@ func runPullsCreate(ctx *cli.Context) error { | |||||||
| 		return nil | 		return nil | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	// push if possible |  | ||||||
| 	err = localRepo.Push(&git.PushOptions{}) |  | ||||||
| 	if err != nil { |  | ||||||
| 		fmt.Printf("Error occurred during 'git push':\n%s\n", err.Error()) |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	pr, _, err := client.CreatePullRequest(ownerArg, repoArg, gitea.CreatePullRequestOption{ | 	pr, _, err := client.CreatePullRequest(ownerArg, repoArg, gitea.CreatePullRequestOption{ | ||||||
| 		Head:  head, | 		Head:  head, | ||||||
| 		Base:  base, | 		Base:  base, | ||||||
| @@ -396,7 +422,7 @@ func runPullsCreate(ctx *cli.Context) error { | |||||||
| 	}) | 	}) | ||||||
|  |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		log.Fatal(err) | 		log.Fatal("could not create PR: ", err) | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	in := fmt.Sprintf("# #%d %s (%s)\n%s created %s\n\n%s\n", pr.Index, | 	in := fmt.Sprintf("# #%d %s (%s)\n%s created %s\n\n%s\n", pr.Index, | ||||||
|   | |||||||
| @@ -176,6 +176,48 @@ func (r TeaRepo) TeaFindBranchByName(branchName, repoURL string) (b *git_config. | |||||||
| 	return b, b.Validate() | 	return b, b.Validate() | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // TeaFindBranchRemote gives the first remote that has a branch with the same name or sha, | ||||||
|  | // depending on what is passed in. | ||||||
|  | // This function is needed, as git does not always define branches in .git/config with remote entries. | ||||||
|  | func (r TeaRepo) TeaFindBranchRemote(branchName, hash string) (*git.Remote, error) { | ||||||
|  | 	remotes, err := r.Remotes() | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	switch { | ||||||
|  | 	case len(remotes) == 0: | ||||||
|  | 		return nil, nil | ||||||
|  | 	case len(remotes) == 1: | ||||||
|  | 		return remotes[0], nil | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	// check if the given remote has our branch (.git/refs/remotes/<remoteName>/*) | ||||||
|  | 	iter, err := r.References() | ||||||
|  | 	if err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
|  | 	defer iter.Close() | ||||||
|  |  | ||||||
|  | 	var match *git.Remote | ||||||
|  | 	err = iter.ForEach(func(ref *git_plumbing.Reference) error { | ||||||
|  | 		if ref.Name().IsRemote() { | ||||||
|  | 			names := strings.SplitN(ref.Name().Short(), "/", 2) | ||||||
|  | 			remote := names[0] | ||||||
|  | 			branch := names[1] | ||||||
|  | 			hashMatch := hash != "" && hash == ref.Hash().String() | ||||||
|  | 			nameMatch := branchName != "" && branchName == branch | ||||||
|  | 			if hashMatch || nameMatch { | ||||||
|  | 				match, err = r.Remote(remote) | ||||||
|  | 				return err | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 		return nil | ||||||
|  | 	}) | ||||||
|  |  | ||||||
|  | 	return match, err | ||||||
|  | } | ||||||
|  |  | ||||||
| // TeaGetCurrentBranchName return the name of the branch witch is currently active | // TeaGetCurrentBranchName return the name of the branch witch is currently active | ||||||
| func (r TeaRepo) TeaGetCurrentBranchName() (string, error) { | func (r TeaRepo) TeaGetCurrentBranchName() (string, error) { | ||||||
| 	localHead, err := r.Head() | 	localHead, err := r.Head() | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Norwin
					Norwin