diff options
author | Máximo Cuadros <mcuadros@gmail.com> | 2018-08-23 01:23:23 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-08-23 01:23:23 +0200 |
commit | 005d5dc961a7053d88da53536f4a5eb4c305529b (patch) | |
tree | d73393383d45b3769c1fb63903a6cf2b02b8d1aa /plumbing/format/packfile/fsobject.go | |
parent | cdfa0bb8d987272b5729e565dbcc64f07963d77d (diff) | |
parent | 790191ef92ec6382ce65cc30286c901863b3b7a3 (diff) | |
download | go-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.go | 10 |
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 |