mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-30 22:11:07 +00:00 
			
		
		
		
	Improve memory usage when reaching diff limits (#2990)
Signed-off-by: Duncan Ogilvie <mr.exodia.tpodt@gmail.com>
This commit is contained in:
		
					parent
					
						
							
								d39b88ae88
							
						
					
				
			
			
				commit
				
					
						c80d147fa9
					
				
			
		
					 1 changed files with 20 additions and 12 deletions
				
			
		|  | @ -252,19 +252,27 @@ func ParsePatch(maxLines, maxLineCharacters, maxFiles int, reader io.Reader) (*D | |||
| 	input := bufio.NewReader(reader) | ||||
| 	isEOF := false | ||||
| 	for !isEOF { | ||||
| 		line, err := input.ReadString('\n') | ||||
| 		if err != nil { | ||||
| 			if err == io.EOF { | ||||
| 				isEOF = true | ||||
| 			} else { | ||||
| 				return nil, fmt.Errorf("ReadString: %v", err) | ||||
| 		var linebuf bytes.Buffer | ||||
| 		for { | ||||
| 			b, err := input.ReadByte() | ||||
| 			if err != nil { | ||||
| 				if err == io.EOF { | ||||
| 					isEOF = true | ||||
| 					break | ||||
| 				} else { | ||||
| 					return nil, fmt.Errorf("ReadByte: %v", err) | ||||
| 				} | ||||
| 			} | ||||
| 			if b == '\n' { | ||||
| 				break | ||||
| 			} | ||||
| 			if linebuf.Len() < maxLineCharacters { | ||||
| 				linebuf.WriteByte(b) | ||||
| 			} else if linebuf.Len() == maxLineCharacters { | ||||
| 				curFile.IsIncomplete = true | ||||
| 			} | ||||
| 		} | ||||
| 
 | ||||
| 		if len(line) > 0 && line[len(line)-1] == '\n' { | ||||
| 			// Remove line break. | ||||
| 			line = line[:len(line)-1] | ||||
| 		} | ||||
| 		line := linebuf.String() | ||||
| 
 | ||||
| 		if strings.HasPrefix(line, "+++ ") || strings.HasPrefix(line, "--- ") || len(line) == 0 { | ||||
| 			continue | ||||
|  | @ -295,7 +303,7 @@ func ParsePatch(maxLines, maxLineCharacters, maxFiles int, reader io.Reader) (*D | |||
| 		lineCount++ | ||||
| 
 | ||||
| 		// Diff data too large, we only show the first about maxLines lines | ||||
| 		if curFileLinesCount >= maxLines || len(line) >= maxLineCharacters { | ||||
| 		if curFileLinesCount >= maxLines { | ||||
| 			curFile.IsIncomplete = true | ||||
| 		} | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue