mirror of
https://github.com/go-gitea/gitea.git
synced 2025-06-26 23:30:58 +08:00
110 lines
2.5 KiB
Go
110 lines
2.5 KiB
Go
// Copyright 2015 The Gogs Authors. All rights reserved.
|
|
// Copyright 2019 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package git
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/base64"
|
|
"errors"
|
|
"io"
|
|
"strings"
|
|
|
|
"code.gitea.io/gitea/modules/typesniffer"
|
|
"code.gitea.io/gitea/modules/util"
|
|
)
|
|
|
|
// This file contains common functions between the gogit and !gogit variants for git Blobs
|
|
|
|
// Name returns name of the tree entry this blob object was created from (or empty string)
|
|
func (b *Blob) Name() string {
|
|
return b.name
|
|
}
|
|
|
|
// GetBlobContent Gets the limited content of the blob as raw text
|
|
func (b *Blob) GetBlobContent(limit int64) (string, error) {
|
|
if limit <= 0 {
|
|
return "", nil
|
|
}
|
|
dataRc, err := b.DataAsync()
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
defer dataRc.Close()
|
|
buf, err := util.ReadWithLimit(dataRc, int(limit))
|
|
return string(buf), err
|
|
}
|
|
|
|
// GetBlobLineCount gets line count of the blob.
|
|
// It will also try to write the content to w if it's not nil, then we could pre-fetch the content without reading it again.
|
|
func (b *Blob) GetBlobLineCount(w io.Writer) (int, error) {
|
|
reader, err := b.DataAsync()
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
defer reader.Close()
|
|
buf := make([]byte, 32*1024)
|
|
count := 1
|
|
lineSep := []byte{'\n'}
|
|
for {
|
|
c, err := reader.Read(buf)
|
|
if w != nil {
|
|
if _, err := w.Write(buf[:c]); err != nil {
|
|
return count, err
|
|
}
|
|
}
|
|
count += bytes.Count(buf[:c], lineSep)
|
|
switch {
|
|
case errors.Is(err, io.EOF):
|
|
return count, nil
|
|
case err != nil:
|
|
return count, err
|
|
}
|
|
}
|
|
}
|
|
|
|
// GetBlobContentBase64 Reads the content of the blob with a base64 encoding and returns the encoded string
|
|
func (b *Blob) GetBlobContentBase64(originContent *strings.Builder) (string, error) {
|
|
dataRc, err := b.DataAsync()
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
defer dataRc.Close()
|
|
|
|
base64buf := &strings.Builder{}
|
|
encoder := base64.NewEncoder(base64.StdEncoding, base64buf)
|
|
buf := make([]byte, 32*1024)
|
|
loop:
|
|
for {
|
|
n, err := dataRc.Read(buf)
|
|
if n > 0 {
|
|
if originContent != nil {
|
|
_, _ = originContent.Write(buf[:n])
|
|
}
|
|
if _, err := encoder.Write(buf[:n]); err != nil {
|
|
return "", err
|
|
}
|
|
}
|
|
switch {
|
|
case errors.Is(err, io.EOF):
|
|
break loop
|
|
case err != nil:
|
|
return "", err
|
|
}
|
|
}
|
|
_ = encoder.Close()
|
|
return base64buf.String(), nil
|
|
}
|
|
|
|
// GuessContentType guesses the content type of the blob.
|
|
func (b *Blob) GuessContentType() (typesniffer.SniffedType, error) {
|
|
r, err := b.DataAsync()
|
|
if err != nil {
|
|
return typesniffer.SniffedType{}, err
|
|
}
|
|
defer r.Close()
|
|
|
|
return typesniffer.DetectContentTypeFromReader(r)
|
|
}
|