2
2
mirror of https://github.com/octoleo/restic.git synced 2025-01-23 15:18:31 +00:00

Remove unneeded pointer to pack id

This commit is contained in:
Alexander Neumann 2015-10-25 14:35:08 +01:00
parent 2710d6399a
commit af0d6f58b9
4 changed files with 24 additions and 24 deletions

View File

@ -26,7 +26,7 @@ type Index struct {
type indexEntry struct { type indexEntry struct {
tpe pack.BlobType tpe pack.BlobType
packID *backend.ID packID backend.ID
offset uint offset uint
length uint length uint
} }
@ -39,7 +39,7 @@ func NewIndex() *Index {
} }
} }
func (idx *Index) store(t pack.BlobType, id backend.ID, pack *backend.ID, offset, length uint) { func (idx *Index) store(t pack.BlobType, id backend.ID, pack backend.ID, offset, length uint) {
idx.pack[id] = indexEntry{ idx.pack[id] = indexEntry{
tpe: t, tpe: t,
packID: pack, packID: pack,
@ -95,7 +95,7 @@ func (idx *Index) Full() bool {
// Store remembers the id and pack in the index. An existing entry will be // Store remembers the id and pack in the index. An existing entry will be
// silently overwritten. // silently overwritten.
func (idx *Index) Store(t pack.BlobType, id backend.ID, pack *backend.ID, offset, length uint) { func (idx *Index) Store(t pack.BlobType, id backend.ID, pack backend.ID, offset, length uint) {
idx.m.Lock() idx.m.Lock()
defer idx.m.Unlock() defer idx.m.Unlock()
@ -110,7 +110,7 @@ func (idx *Index) Store(t pack.BlobType, id backend.ID, pack *backend.ID, offset
} }
// Lookup returns the pack for the id. // Lookup returns the pack for the id.
func (idx *Index) Lookup(id backend.ID) (packID *backend.ID, tpe pack.BlobType, offset, length uint, err error) { func (idx *Index) Lookup(id backend.ID) (packID backend.ID, tpe pack.BlobType, offset, length uint, err error) {
idx.m.Lock() idx.m.Lock()
defer idx.m.Unlock() defer idx.m.Unlock()
@ -121,7 +121,7 @@ func (idx *Index) Lookup(id backend.ID) (packID *backend.ID, tpe pack.BlobType,
} }
debug.Log("Index.Lookup", "id %v not found", id.Str()) debug.Log("Index.Lookup", "id %v not found", id.Str())
return nil, pack.Data, 0, 0, fmt.Errorf("id %v not found in index", id) return backend.ID{}, pack.Data, 0, 0, fmt.Errorf("id %v not found in index", id)
} }
// Has returns true iff the id is listed in the index. // Has returns true iff the id is listed in the index.
@ -196,7 +196,7 @@ func (idx *Index) Each(done chan struct{}) <-chan PackedBlob {
Type: blob.tpe, Type: blob.tpe,
Length: blob.length, Length: blob.length,
}, },
PackID: *blob.packID, PackID: blob.packID,
}: }:
} }
} }
@ -239,8 +239,8 @@ func (idx *Index) generatePackList() ([]*packJSON, error) {
packs := make(map[backend.ID]*packJSON) packs := make(map[backend.ID]*packJSON)
for id, blob := range idx.pack { for id, blob := range idx.pack {
if blob.packID == nil { if blob.packID.IsNull() {
panic("nil pack id") panic("null pack id")
} }
debug.Log("Index.generatePackList", "handle blob %v", id.Str()) debug.Log("Index.generatePackList", "handle blob %v", id.Str())
@ -252,10 +252,10 @@ func (idx *Index) generatePackList() ([]*packJSON, error) {
} }
// see if pack is already in map // see if pack is already in map
p, ok := packs[*blob.packID] p, ok := packs[blob.packID]
if !ok { if !ok {
// else create new pack // else create new pack
p = &packJSON{ID: *blob.packID} p = &packJSON{ID: blob.packID}
// and append it to the list and map // and append it to the list and map
list = append(list, p) list = append(list, p)
@ -380,7 +380,7 @@ func DecodeIndex(rd io.Reader) (idx *Index, err error) {
idx = NewIndex() idx = NewIndex()
for _, pack := range idxJSON.Packs { for _, pack := range idxJSON.Packs {
for _, blob := range pack.Blobs { for _, blob := range pack.Blobs {
idx.store(blob.Type, blob.ID, &pack.ID, blob.Offset, blob.Length) idx.store(blob.Type, blob.ID, pack.ID, blob.Offset, blob.Length)
} }
} }
idx.supersedes = idxJSON.Supersedes idx.supersedes = idxJSON.Supersedes
@ -405,7 +405,7 @@ func DecodeOldIndex(rd io.Reader) (idx *Index, err error) {
idx = NewIndex() idx = NewIndex()
for _, pack := range list { for _, pack := range list {
for _, blob := range pack.Blobs { for _, blob := range pack.Blobs {
idx.store(blob.Type, blob.ID, &pack.ID, blob.Offset, blob.Length) idx.store(blob.Type, blob.ID, pack.ID, blob.Offset, blob.Length)
} }
} }

View File

@ -41,7 +41,7 @@ func TestIndexSerialize(t *testing.T) {
for j := 0; j < 20; j++ { for j := 0; j < 20; j++ {
id := randomID() id := randomID()
length := uint(i*100 + j) length := uint(i*100 + j)
idx.Store(pack.Data, id, &packID, pos, length) idx.Store(pack.Data, id, packID, pos, length)
tests = append(tests, testEntry{ tests = append(tests, testEntry{
id: id, id: id,
@ -72,7 +72,7 @@ func TestIndexSerialize(t *testing.T) {
packID, tpe, offset, length, err := idx.Lookup(testBlob.id) packID, tpe, offset, length, err := idx.Lookup(testBlob.id)
OK(t, err) OK(t, err)
Equals(t, testBlob.pack, *packID) Equals(t, testBlob.pack, packID)
Equals(t, testBlob.tpe, tpe) Equals(t, testBlob.tpe, tpe)
Equals(t, testBlob.offset, offset) Equals(t, testBlob.offset, offset)
Equals(t, testBlob.length, length) Equals(t, testBlob.length, length)
@ -80,7 +80,7 @@ func TestIndexSerialize(t *testing.T) {
packID, tpe, offset, length, err = idx2.Lookup(testBlob.id) packID, tpe, offset, length, err = idx2.Lookup(testBlob.id)
OK(t, err) OK(t, err)
Equals(t, testBlob.pack, *packID) Equals(t, testBlob.pack, packID)
Equals(t, testBlob.tpe, tpe) Equals(t, testBlob.tpe, tpe)
Equals(t, testBlob.offset, offset) Equals(t, testBlob.offset, offset)
Equals(t, testBlob.length, length) Equals(t, testBlob.length, length)
@ -95,7 +95,7 @@ func TestIndexSerialize(t *testing.T) {
for j := 0; j < 10; j++ { for j := 0; j < 10; j++ {
id := randomID() id := randomID()
length := uint(i*100 + j) length := uint(i*100 + j)
idx.Store(pack.Data, id, &packID, pos, length) idx.Store(pack.Data, id, packID, pos, length)
newtests = append(newtests, testEntry{ newtests = append(newtests, testEntry{
id: id, id: id,
@ -129,7 +129,7 @@ func TestIndexSerialize(t *testing.T) {
packID, tpe, offset, length, err := idx3.Lookup(testBlob.id) packID, tpe, offset, length, err := idx3.Lookup(testBlob.id)
OK(t, err) OK(t, err)
Equals(t, testBlob.pack, *packID) Equals(t, testBlob.pack, packID)
Equals(t, testBlob.tpe, tpe) Equals(t, testBlob.tpe, tpe)
Equals(t, testBlob.offset, offset) Equals(t, testBlob.offset, offset)
Equals(t, testBlob.length, length) Equals(t, testBlob.length, length)
@ -148,7 +148,7 @@ func TestIndexSize(t *testing.T) {
for j := 0; j < blobs; j++ { for j := 0; j < blobs; j++ {
id := randomID() id := randomID()
length := uint(i*100 + j) length := uint(i*100 + j)
idx.Store(pack.Data, id, &packID, pos, length) idx.Store(pack.Data, id, packID, pos, length)
pos += length pos += length
} }
@ -250,7 +250,7 @@ func TestIndexUnserialize(t *testing.T) {
packID, tpe, offset, length, err := idx.Lookup(test.id) packID, tpe, offset, length, err := idx.Lookup(test.id)
OK(t, err) OK(t, err)
Equals(t, test.packID, *packID) Equals(t, test.packID, packID)
Equals(t, test.tpe, tpe) Equals(t, test.tpe, tpe)
Equals(t, test.offset, offset) Equals(t, test.offset, offset)
Equals(t, test.length, length) Equals(t, test.length, length)
@ -267,7 +267,7 @@ func TestIndexUnserializeOld(t *testing.T) {
packID, tpe, offset, length, err := idx.Lookup(test.id) packID, tpe, offset, length, err := idx.Lookup(test.id)
OK(t, err) OK(t, err)
Equals(t, test.packID, *packID) Equals(t, test.packID, packID)
Equals(t, test.tpe, tpe) Equals(t, test.tpe, tpe)
Equals(t, test.offset, offset) Equals(t, test.offset, offset)
Equals(t, test.length, length) Equals(t, test.length, length)
@ -313,7 +313,7 @@ func TestConvertIndex(t *testing.T) {
packID, tpe, offset, length, err := oldIndex.Lookup(packedBlob.ID) packID, tpe, offset, length, err := oldIndex.Lookup(packedBlob.ID)
OK(t, err) OK(t, err)
Assert(t, *packID == packedBlob.PackID, Assert(t, packID == packedBlob.PackID,
"Check blob %v: pack ID %v != %v", packedBlob.ID, packID, packedBlob.PackID) "Check blob %v: pack ID %v != %v", packedBlob.ID, packID, packedBlob.PackID)
Assert(t, tpe == packedBlob.Type, Assert(t, tpe == packedBlob.Type,
"Check blob %v: Type %v != %v", packedBlob.ID, tpe, packedBlob.Type) "Check blob %v: Type %v != %v", packedBlob.ID, tpe, packedBlob.Type)

View File

@ -33,7 +33,7 @@ func NewMasterIndex() *MasterIndex {
} }
// Lookup queries all known Indexes for the ID and returns the first match. // Lookup queries all known Indexes for the ID and returns the first match.
func (mi *MasterIndex) Lookup(id backend.ID) (packID *backend.ID, tpe pack.BlobType, offset, length uint, err error) { func (mi *MasterIndex) Lookup(id backend.ID) (packID backend.ID, tpe pack.BlobType, offset, length uint, err error) {
mi.idxMutex.RLock() mi.idxMutex.RLock()
defer mi.idxMutex.RUnlock() defer mi.idxMutex.RUnlock()
@ -50,7 +50,7 @@ func (mi *MasterIndex) Lookup(id backend.ID) (packID *backend.ID, tpe pack.BlobT
} }
debug.Log("MasterIndex.Lookup", "id %v not found in any index", id.Str()) debug.Log("MasterIndex.Lookup", "id %v not found in any index", id.Str())
return nil, pack.Data, 0, 0, fmt.Errorf("id %v not found in any index", id) return backend.ID{}, pack.Data, 0, 0, fmt.Errorf("id %v not found in any index", id)
} }
// LookupSize queries all known Indexes for the ID and returns the first match. // LookupSize queries all known Indexes for the ID and returns the first match.

View File

@ -269,7 +269,7 @@ func (r *Repository) savePacker(p *pack.Packer) error {
// update blobs in the index // update blobs in the index
for _, b := range p.Blobs() { for _, b := range p.Blobs() {
debug.Log("Repo.savePacker", " updating blob %v to pack %v", b.ID.Str(), sid.Str()) debug.Log("Repo.savePacker", " updating blob %v to pack %v", b.ID.Str(), sid.Str())
r.idx.Current().Store(b.Type, b.ID, &sid, b.Offset, uint(b.Length)) r.idx.Current().Store(b.Type, b.ID, sid, b.Offset, uint(b.Length))
r.idx.RemoveFromInFlight(b.ID) r.idx.RemoveFromInFlight(b.ID)
} }