aboutsummaryrefslogtreecommitdiffstats
path: root/storage/memory/object.go
blob: 1720ebd00dc37a4c09d9a94a9fbaa7a97aa47414 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
package memory

import (
	"bytes"
	"io/ioutil"

	"gopkg.in/src-d/go-git.v3/core"
)

// Object on memory core.Object implementation
type Object struct {
	t    core.ObjectType
	h    core.Hash
	cont []byte
	sz   int64
}

// NewObject creates a new object with the given type and content
func NewObject(typ core.ObjectType, size int64, cont []byte) *Object {
	return &Object{
		t:    typ,
		h:    core.ComputeHash(typ, cont),
		cont: cont,
		sz:   int64(len(cont)),
	}
}

// Hash return the object Hash, the hash is calculated on-the-fly the first
// time is called, the subsequent calls the same Hash is returned even if the
// type or the content has changed. The Hash is only generated if the size of
// the content is exactly the Object.Size
func (o *Object) Hash() core.Hash {
	if o.h == core.ZeroHash && int64(len(o.cont)) == o.sz {
		o.h = core.ComputeHash(o.t, o.cont)
	}

	return o.h
}

// Type return the core.ObjectType
func (o *Object) Type() core.ObjectType { return o.t }

// SetType sets the core.ObjectType
func (o *Object) SetType(t core.ObjectType) { o.t = t }

// Size return the size of the object
func (o *Object) Size() int64 { return o.sz }

// SetSize set the object size, the given size should be written afterwards
func (o *Object) SetSize(s int64) { o.sz = s }

// Content returns the contents of the object
func (o *Object) Content() []byte { return o.cont }

// Reader returns a core.ObjectReader used to read the object's content.
func (o *Object) Reader() (core.ObjectReader, error) {
	return ioutil.NopCloser(bytes.NewBuffer(o.cont)), nil
}

// Writer returns a core.ObjectWriter used to write the object's content.
func (o *Object) Writer() (core.ObjectWriter, error) {
	return o, nil
}

func (o *Object) Write(p []byte) (n int, err error) {
	o.cont = append(o.cont, p...)
	return len(p), nil
}

// Close releases any resources consumed by the object when it is acting as a
// core.ObjectWriter.
func (o *Object) Close() error { return nil }