mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	Fix slow patch checking with commits that add or remove many files (#31548)
Running git update-index for every individual file is slow, so add and remove everything with a single git command. When such a big commit lands in the default branch, it could cause PR creation and patch checking for all open PRs to be slow, or time out entirely. For example, a commit that removes 1383 files was measured to take more than 60 seconds and timed out. With this change checking took about a second. This is related to #27967, though this will not help with commits that change many lines in few files.
This commit is contained in:
		
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			
						parent
						
							2c92c7c522
						
					
				
				
					commit
					b88e5fc72d
				
			| @@ -104,11 +104,8 @@ func (repo *Repository) RemoveFilesFromIndex(filenames ...string) error { | ||||
| 	buffer := new(bytes.Buffer) | ||||
| 	for _, file := range filenames { | ||||
| 		if file != "" { | ||||
| 			buffer.WriteString("0 ") | ||||
| 			buffer.WriteString(objectFormat.EmptyObjectID().String()) | ||||
| 			buffer.WriteByte('\t') | ||||
| 			buffer.WriteString(file) | ||||
| 			buffer.WriteByte('\000') | ||||
| 			// using format: mode SP type SP sha1 TAB path | ||||
| 			buffer.WriteString("0 blob " + objectFormat.EmptyObjectID().String() + "\t" + file + "\000") | ||||
| 		} | ||||
| 	} | ||||
| 	return cmd.Run(&RunOpts{ | ||||
| @@ -119,11 +116,33 @@ func (repo *Repository) RemoveFilesFromIndex(filenames ...string) error { | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| type IndexObjectInfo struct { | ||||
| 	Mode     string | ||||
| 	Object   ObjectID | ||||
| 	Filename string | ||||
| } | ||||
|  | ||||
| // AddObjectsToIndex adds the provided object hashes to the index at the provided filenames | ||||
| func (repo *Repository) AddObjectsToIndex(objects ...IndexObjectInfo) error { | ||||
| 	cmd := NewCommand(repo.Ctx, "update-index", "--add", "--replace", "-z", "--index-info") | ||||
| 	stdout := new(bytes.Buffer) | ||||
| 	stderr := new(bytes.Buffer) | ||||
| 	buffer := new(bytes.Buffer) | ||||
| 	for _, object := range objects { | ||||
| 		// using format: mode SP type SP sha1 TAB path | ||||
| 		buffer.WriteString(object.Mode + " blob " + object.Object.String() + "\t" + object.Filename + "\000") | ||||
| 	} | ||||
| 	return cmd.Run(&RunOpts{ | ||||
| 		Dir:    repo.Path, | ||||
| 		Stdin:  bytes.NewReader(buffer.Bytes()), | ||||
| 		Stdout: stdout, | ||||
| 		Stderr: stderr, | ||||
| 	}) | ||||
| } | ||||
|  | ||||
| // AddObjectToIndex adds the provided object hash to the index at the provided filename | ||||
| func (repo *Repository) AddObjectToIndex(mode string, object ObjectID, filename string) error { | ||||
| 	cmd := NewCommand(repo.Ctx, "update-index", "--add", "--replace", "--cacheinfo").AddDynamicArguments(mode, object.String(), filename) | ||||
| 	_, _, err := cmd.RunStdString(&RunOpts{Dir: repo.Path}) | ||||
| 	return err | ||||
| 	return repo.AddObjectsToIndex(IndexObjectInfo{Mode: mode, Object: object, Filename: filename}) | ||||
| } | ||||
|  | ||||
| // WriteTree writes the current index as a tree to the object db and returns its hash | ||||
|   | ||||
		Reference in New Issue
	
	Block a user