From e33d9e77f43e6829ea967e47964d13f5a8aec5cc Mon Sep 17 00:00:00 2001 From: Unknwon Date: Sun, 27 May 2018 09:07:15 +0800 Subject: vendor: rename "gogits" to "gogs" --- vendor/github.com/gogs/git-module/blob.go | 35 +++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 vendor/github.com/gogs/git-module/blob.go (limited to 'vendor/github.com/gogs/git-module/blob.go') diff --git a/vendor/github.com/gogs/git-module/blob.go b/vendor/github.com/gogs/git-module/blob.go new file mode 100644 index 00000000..7731226d --- /dev/null +++ b/vendor/github.com/gogs/git-module/blob.go @@ -0,0 +1,35 @@ +// Copyright 2015 The Gogs Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package git + +import ( + "bytes" + "io" +) + +// Blob represents a Git object. +type Blob struct { + repo *Repository + *TreeEntry +} + +// Data gets content of blob all at once and wrap it as io.Reader. +// This can be very slow and memory consuming for huge content. +func (b *Blob) Data() (io.Reader, error) { + stdout := new(bytes.Buffer) + stderr := new(bytes.Buffer) + + // Preallocate memory to save ~50% memory usage on big files. + stdout.Grow(int(b.Size() + 2048)) + + if err := b.DataPipeline(stdout, stderr); err != nil { + return nil, concatenateError(err, stderr.String()) + } + return stdout, nil +} + +func (b *Blob) DataPipeline(stdout, stderr io.Writer) error { + return NewCommand("show", b.ID.String()).RunInDirPipeline(b.repo.Path, stdout, stderr) +} -- cgit v1.2.3