Rename bytePostings To bigEndianPostings

* To be more specific about the contents of the byte slice.
This commit is contained in:
Goutham Veeramachaneni 2017-03-27 14:04:42 +05:30
parent efb0dfe1be
commit 7b94a4e17d
No known key found for this signature in database
GPG key ID: F1C217E8E9023CAD
2 changed files with 10 additions and 8 deletions

View file

@ -702,7 +702,7 @@ func (r *indexReader) Postings(name, value string) (Postings, error) {
if len(b)%4 != 0 {
return nil, errors.Wrap(errInvalidSize, "plain postings entry")
}
return newBytePostings(b), nil
return newBigEndianPostings(b), nil
}
type stringTuples struct {

View file

@ -241,26 +241,28 @@ func (it *listPostings) Err() error {
return nil
}
type bytePostings struct {
// bigEndianPostings implements the Postings interface over a byte stream of
// big endian numbers.
type bigEndianPostings struct {
list []byte
idx int
}
func newBytePostings(list []byte) *bytePostings {
return &bytePostings{list: list, idx: -1}
func newBigEndianPostings(list []byte) *bigEndianPostings {
return &bigEndianPostings{list: list, idx: -1}
}
func (it *bytePostings) At() uint32 {
func (it *bigEndianPostings) At() uint32 {
idx := 4 * it.idx
return binary.BigEndian.Uint32(it.list[idx : idx+4])
}
func (it *bytePostings) Next() bool {
func (it *bigEndianPostings) Next() bool {
it.idx++
return it.idx*4 < len(it.list)
}
func (it *bytePostings) Seek(x uint32) bool {
func (it *bigEndianPostings) Seek(x uint32) bool {
num := len(it.list) / 4
// Do binary search between current position and end.
it.idx += sort.Search(num-it.idx, func(i int) bool {
@ -271,7 +273,7 @@ func (it *bytePostings) Seek(x uint32) bool {
return it.idx*4 < len(it.list)
}
func (it *bytePostings) Err() error {
func (it *bigEndianPostings) Err() error {
return nil
}