mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 01:30:53 +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:
		
				
					committed by
					
						
						Lauris BH
					
				
			
			
				
	
			
			
			
						parent
						
							d39b88ae88
						
					
				
				
					commit
					c80d147fa9
				
			@@ -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')
 | 
			
		||||
		var linebuf bytes.Buffer
 | 
			
		||||
		for {
 | 
			
		||||
			b, err := input.ReadByte()
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				if err == io.EOF {
 | 
			
		||||
					isEOF = true
 | 
			
		||||
					break
 | 
			
		||||
				} else {
 | 
			
		||||
				return nil, fmt.Errorf("ReadString: %v", err)
 | 
			
		||||
					return nil, fmt.Errorf("ReadByte: %v", err)
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
		if len(line) > 0 && line[len(line)-1] == '\n' {
 | 
			
		||||
			// Remove line break.
 | 
			
		||||
			line = line[:len(line)-1]
 | 
			
		||||
			if b == '\n' {
 | 
			
		||||
				break
 | 
			
		||||
			}
 | 
			
		||||
			if linebuf.Len() < maxLineCharacters {
 | 
			
		||||
				linebuf.WriteByte(b)
 | 
			
		||||
			} else if linebuf.Len() == maxLineCharacters {
 | 
			
		||||
				curFile.IsIncomplete = true
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
		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
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user