mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 11:57:28 -04:00 
			
		
		
		
	Use git log name-status in get last commit (#16059)
* Improve get last commit using git log --name-status git log --name-status -c provides information about the diff between a commit and its parents. Using this and adjusting the algorithm to use the first change to a path allows for a much faster generation of commit info. There is a subtle change in the results generated but this will cause the results to more closely match those from elsewhere. Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: techknowlogick <techknowlogick@gitea.io> Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
		
							
								
								
									
										58
									
								
								vendor/github.com/djherbis/buffer/ring.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										58
									
								
								vendor/github.com/djherbis/buffer/ring.go
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,58 @@ | ||||
| package buffer | ||||
|  | ||||
| import ( | ||||
| 	"io" | ||||
| 	"math" | ||||
|  | ||||
| 	"github.com/djherbis/buffer/wrapio" | ||||
| ) | ||||
|  | ||||
| type ring struct { | ||||
| 	BufferAt | ||||
| 	L int64 | ||||
| 	*wrapio.WrapReader | ||||
| 	*wrapio.WrapWriter | ||||
| } | ||||
|  | ||||
| // NewRing returns a Ring Buffer from a BufferAt. | ||||
| // It overwrites old data in the Buffer when needed (when its full). | ||||
| func NewRing(buffer BufferAt) Buffer { | ||||
| 	return &ring{ | ||||
| 		BufferAt:   buffer, | ||||
| 		WrapReader: wrapio.NewWrapReader(buffer, 0, buffer.Cap()), | ||||
| 		WrapWriter: wrapio.NewWrapWriter(buffer, 0, buffer.Cap()), | ||||
| 	} | ||||
| } | ||||
|  | ||||
| func (buf *ring) Len() int64 { | ||||
| 	return buf.L | ||||
| } | ||||
|  | ||||
| func (buf *ring) Cap() int64 { | ||||
| 	return math.MaxInt64 | ||||
| } | ||||
|  | ||||
| func (buf *ring) Read(p []byte) (n int, err error) { | ||||
| 	if buf.L == buf.BufferAt.Cap() { | ||||
| 		buf.WrapReader.Seek(buf.WrapWriter.Offset(), 0) | ||||
| 	} | ||||
| 	n, err = io.LimitReader(buf.WrapReader, buf.L).Read(p) | ||||
| 	buf.L -= int64(n) | ||||
| 	return n, err | ||||
| } | ||||
|  | ||||
| func (buf *ring) Write(p []byte) (n int, err error) { | ||||
| 	n, err = buf.WrapWriter.Write(p) | ||||
| 	buf.L += int64(n) | ||||
| 	if buf.L > buf.BufferAt.Cap() { | ||||
| 		buf.L = buf.BufferAt.Cap() | ||||
| 	} | ||||
| 	return n, err | ||||
| } | ||||
|  | ||||
| func (buf *ring) Reset() { | ||||
| 	buf.BufferAt.Reset() | ||||
| 	buf.L = 0 | ||||
| 	buf.WrapReader = wrapio.NewWrapReader(buf.BufferAt, 0, buf.BufferAt.Cap()) | ||||
| 	buf.WrapWriter = wrapio.NewWrapWriter(buf.BufferAt, 0, buf.BufferAt.Cap()) | ||||
| } | ||||
		Reference in New Issue
	
	Block a user