aboutsummaryrefslogtreecommitdiffstats
path: root/plumbing/format/packfile/fsobject.go
diff options
context:
space:
mode:
authorMáximo Cuadros <mcuadros@gmail.com>2018-08-23 01:23:23 +0200
committerGitHub <noreply@github.com>2018-08-23 01:23:23 +0200
commit005d5dc961a7053d88da53536f4a5eb4c305529b (patch)
treed73393383d45b3769c1fb63903a6cf2b02b8d1aa /plumbing/format/packfile/fsobject.go
parentcdfa0bb8d987272b5729e565dbcc64f07963d77d (diff)
parent790191ef92ec6382ce65cc30286c901863b3b7a3 (diff)
downloadgo-git-005d5dc961a7053d88da53536f4a5eb4c305529b.tar.gz
Merge pull request #929 from jfontan/fix/reuse-base-cache
plumbing, storage: add bases to the common cache
Diffstat (limited to 'plumbing/format/packfile/fsobject.go')
-rw-r--r--plumbing/format/packfile/fsobject.go10
1 files changed, 10 insertions, 0 deletions
diff --git a/plumbing/format/packfile/fsobject.go b/plumbing/format/packfile/fsobject.go
index 6fd3ca5..330cb73 100644
--- a/plumbing/format/packfile/fsobject.go
+++ b/plumbing/format/packfile/fsobject.go
@@ -47,6 +47,16 @@ func NewFSObject(
// Reader implements the plumbing.EncodedObject interface.
func (o *FSObject) Reader() (io.ReadCloser, error) {
+ obj, ok := o.cache.Get(o.hash)
+ if ok {
+ reader, err := obj.Reader()
+ if err != nil {
+ return nil, err
+ }
+
+ return reader, nil
+ }
+
f, err := o.fs.Open(o.path)
if err != nil {
return nil, err