Add ID handling for index

This commit is contained in:
Alexander Neumann 2015-11-02 18:51:45 +01:00
parent 60a34087c9
commit f3f84b1544
3 changed files with 43 additions and 2 deletions

View file

@ -20,6 +20,7 @@ type Index struct {
pack map[backend.ID]indexEntry pack map[backend.ID]indexEntry
final bool // set to true for all indexes read from the backend ("finalized") final bool // set to true for all indexes read from the backend ("finalized")
id backend.ID // set to the ID of the index when it's finalized
supersedes backend.IDs supersedes backend.IDs
created time.Time created time.Time
} }
@ -395,6 +396,39 @@ func (idx *Index) Finalize(w io.Writer) error {
return idx.encode(w) return idx.encode(w)
} }
// ID returns the ID of the index, if available. If the index is not yet
// finalized, an error is returned.
func (idx *Index) ID() (backend.ID, error) {
idx.m.Lock()
defer idx.m.Unlock()
if !idx.final {
return backend.ID{}, errors.New("index not finalized")
}
return idx.id, nil
}
// SetID sets the ID the index has been written to. This requires that
// Finalize() has been called before, otherwise an error is returned.
func (idx *Index) SetID(id backend.ID) error {
idx.m.Lock()
defer idx.m.Unlock()
if !idx.final {
return errors.New("indexs is not final")
}
if !idx.id.IsNull() {
return errors.New("ID already set")
}
debug.Log("Index.SetID", "ID set to %v", id.Str())
idx.id = id
return nil
}
// Dump writes the pretty-printed JSON representation of the index to w. // Dump writes the pretty-printed JSON representation of the index to w.
func (idx *Index) Dump(w io.Writer) error { func (idx *Index) Dump(w io.Writer) error {
debug.Log("Index.Dump", "dumping index") debug.Log("Index.Dump", "dumping index")

View file

@ -117,6 +117,12 @@ func TestIndexSerialize(t *testing.T) {
Assert(t, idx.Final(), Assert(t, idx.Final(),
"index not final after encoding") "index not final after encoding")
id := randomID()
idx.SetID(id)
id2, err := idx.ID()
Assert(t, id2.Equal(id),
"wrong ID returned: want %v, got %v", id, id2)
idx3, err := repository.DecodeIndex(wr3) idx3, err := repository.DecodeIndex(wr3)
OK(t, err) OK(t, err)
Assert(t, idx3 != nil, Assert(t, idx3 != nil,

View file

@ -526,7 +526,8 @@ func SaveIndex(repo *Repository, index *Index) (backend.ID, error) {
} }
sid := blob.ID() sid := blob.ID()
return sid, nil err = index.SetID(sid)
return sid, err
} }
// saveIndex saves all indexes in the backend. // saveIndex saves all indexes in the backend.