mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	* 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>
		
			
				
	
	
		
			48 lines
		
	
	
		
			977 B
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			977 B
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
| package buffer
 | |
| 
 | |
| import "math"
 | |
| 
 | |
| // ListAt is a slice of BufferAt's, it's the backing for NewPartitionAt
 | |
| type ListAt []BufferAt
 | |
| 
 | |
| // Len is the sum of the Len()'s of the BufferAt's in the list.
 | |
| func (l *ListAt) Len() (n int64) {
 | |
| 	for _, buffer := range *l {
 | |
| 		if n > math.MaxInt64-buffer.Len() {
 | |
| 			return math.MaxInt64
 | |
| 		}
 | |
| 		n += buffer.Len()
 | |
| 	}
 | |
| 	return n
 | |
| }
 | |
| 
 | |
| // Cap is the sum of the Cap()'s of the BufferAt's in the list.
 | |
| func (l *ListAt) Cap() (n int64) {
 | |
| 	for _, buffer := range *l {
 | |
| 		if n > math.MaxInt64-buffer.Cap() {
 | |
| 			return math.MaxInt64
 | |
| 		}
 | |
| 		n += buffer.Cap()
 | |
| 	}
 | |
| 	return n
 | |
| }
 | |
| 
 | |
| // Reset calls Reset() on each of the BufferAt's in the list.
 | |
| func (l *ListAt) Reset() {
 | |
| 	for _, buffer := range *l {
 | |
| 		buffer.Reset()
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Push adds a BufferAt to the end of the list
 | |
| func (l *ListAt) Push(b BufferAt) {
 | |
| 	*l = append(*l, b)
 | |
| }
 | |
| 
 | |
| // Pop removes and returns a BufferAt from the front of the list
 | |
| func (l *ListAt) Pop() (b BufferAt) {
 | |
| 	b = (*l)[0]
 | |
| 	*l = (*l)[1:]
 | |
| 	return b
 | |
| }
 |