mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-23 00:24:21 +02:00 
			
		
		
		
	Backport #14624 GetCommit() assumes that all 40 char strings are SHA1s. This leads to an error if you try to do a PR on a branch which is 40 characters long. This PR attempts the SHA first - and if it fails will switch to using rev-parse. Fix #14470 Signed-off-by: Andrew Thornton <art27@cantab.net>
This commit is contained in:
		
							parent
							
								
									82637c240a
								
							
						
					
					
						commit
						101fb0d7e2
					
				| @ -129,19 +129,23 @@ func (repo *Repository) getCommit(id SHA1) (*Commit, error) { | ||||
| 
 | ||||
| // ConvertToSHA1 returns a Hash object from a potential ID string | ||||
| func (repo *Repository) ConvertToSHA1(commitID string) (SHA1, error) { | ||||
| 	if len(commitID) != 40 { | ||||
| 		var err error | ||||
| 		actualCommitID, err := NewCommand("rev-parse", "--verify", commitID).RunInDir(repo.Path) | ||||
| 		if err != nil { | ||||
| 			if strings.Contains(err.Error(), "unknown revision or path") || | ||||
| 				strings.Contains(err.Error(), "fatal: Needed a single revision") { | ||||
| 				return SHA1{}, ErrNotExist{commitID, ""} | ||||
| 			} | ||||
| 			return SHA1{}, err | ||||
| 	if len(commitID) == 40 { | ||||
| 		sha1, err := NewIDFromString(commitID) | ||||
| 		if err == nil { | ||||
| 			return sha1, nil | ||||
| 		} | ||||
| 		commitID = actualCommitID | ||||
| 	} | ||||
| 	return NewIDFromString(commitID) | ||||
| 
 | ||||
| 	actualCommitID, err := NewCommand("rev-parse", "--verify", commitID).RunInDir(repo.Path) | ||||
| 	if err != nil { | ||||
| 		if strings.Contains(err.Error(), "unknown revision or path") || | ||||
| 			strings.Contains(err.Error(), "fatal: Needed a single revision") { | ||||
| 			return SHA1{}, ErrNotExist{commitID, ""} | ||||
| 		} | ||||
| 		return SHA1{}, err | ||||
| 	} | ||||
| 
 | ||||
| 	return NewIDFromString(actualCommitID) | ||||
| } | ||||
| 
 | ||||
| // GetCommit returns commit object of by ID string. | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user