mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +08:00 
			
		
		
		
	Use native git variants by default with go-git variants as build tag (#13673)
* Move last commit cache back into modules/git Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove go-git from the interface for last commit cache Signed-off-by: Andrew Thornton <art27@cantab.net> * move cacheref to last_commit_cache Signed-off-by: Andrew Thornton <art27@cantab.net> * Remove go-git from routers/private/hook Signed-off-by: Andrew Thornton <art27@cantab.net> * Move FindLFSFiles to pipeline Signed-off-by: Andrew Thornton <art27@cantab.net> * Make no-go-git variants Signed-off-by: Andrew Thornton <art27@cantab.net> * Submodule RefID Signed-off-by: Andrew Thornton <art27@cantab.net> * fix issue with GetCommitsInfo Signed-off-by: Andrew Thornton <art27@cantab.net> * fix GetLastCommitForPaths Signed-off-by: Andrew Thornton <art27@cantab.net> * Improve efficiency Signed-off-by: Andrew Thornton <art27@cantab.net> * More efficiency Signed-off-by: Andrew Thornton <art27@cantab.net> * even faster Signed-off-by: Andrew Thornton <art27@cantab.net> * Reduce duplication * As per @lunny Signed-off-by: Andrew Thornton <art27@cantab.net> * attempt to fix drone Signed-off-by: Andrew Thornton <art27@cantab.net> * fix test-tags Signed-off-by: Andrew Thornton <art27@cantab.net> * default to use no-go-git variants and add gogit build tag Signed-off-by: Andrew Thornton <art27@cantab.net> * placate lint Signed-off-by: Andrew Thornton <art27@cantab.net> * as per @6543 Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
This commit is contained in:
		@@ -6,6 +6,7 @@ package git
 | 
			
		||||
 | 
			
		||||
import (
 | 
			
		||||
	"fmt"
 | 
			
		||||
	"io"
 | 
			
		||||
	"os"
 | 
			
		||||
	"strconv"
 | 
			
		||||
	"strings"
 | 
			
		||||
@@ -68,11 +69,12 @@ func isExist(path string) bool {
 | 
			
		||||
	return err == nil || os.IsExist(err)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func concatenateError(err error, stderr string) error {
 | 
			
		||||
// ConcatenateError concatenats an error with stderr string
 | 
			
		||||
func ConcatenateError(err error, stderr string) error {
 | 
			
		||||
	if len(stderr) == 0 {
 | 
			
		||||
		return err
 | 
			
		||||
	}
 | 
			
		||||
	return fmt.Errorf("%v - %s", err, stderr)
 | 
			
		||||
	return fmt.Errorf("%w - %s", err, stderr)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// RefEndName return the end name of a ref name
 | 
			
		||||
@@ -140,3 +142,29 @@ func ParseBool(value string) (result bool, valid bool) {
 | 
			
		||||
	}
 | 
			
		||||
	return intValue != 0, true
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// LimitedReaderCloser is a limited reader closer
 | 
			
		||||
type LimitedReaderCloser struct {
 | 
			
		||||
	R io.Reader
 | 
			
		||||
	C io.Closer
 | 
			
		||||
	N int64
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Read implements io.Reader
 | 
			
		||||
func (l *LimitedReaderCloser) Read(p []byte) (n int, err error) {
 | 
			
		||||
	if l.N <= 0 {
 | 
			
		||||
		_ = l.C.Close()
 | 
			
		||||
		return 0, io.EOF
 | 
			
		||||
	}
 | 
			
		||||
	if int64(len(p)) > l.N {
 | 
			
		||||
		p = p[0:l.N]
 | 
			
		||||
	}
 | 
			
		||||
	n, err = l.R.Read(p)
 | 
			
		||||
	l.N -= int64(n)
 | 
			
		||||
	return
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Close implements io.Closer
 | 
			
		||||
func (l *LimitedReaderCloser) Close() error {
 | 
			
		||||
	return l.C.Close()
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user