Fixed non-interleaved LevelDB backend.

This commit is contained in:
Sascha L. Teichmann 2015-07-24 13:15:05 +02:00
parent fe6a551f06
commit c9686a7f24

View File

@ -314,42 +314,34 @@ func (ldbs *LevelDBSession) plainSpatialQuery(
ro := leveldb.NewReadOptions() ro := leveldb.NewReadOptions()
defer ro.Close() defer ro.Close()
ro.SetFillCache(false)
it := ldbs.backend.db.NewIterator(ro)
defer it.Close()
var a, b common.Coord var a, b common.Coord
var err error
for _, r := range ldbs.backend.coverage.Query(c1, c2) { for _, r := range ldbs.backend.coverage.Query(c1, c2) {
a.Z, b.Z = int16(r.Z), int16(r.Z) a.Z, b.Z = int16(r.Z), int16(r.Z)
a.X, b.X = int16(r.X1), int16(r.X2) a.X, b.X = int16(r.X1), int16(r.X2)
// log.Printf("y1 y2 x1 x2 z: %d %d, %d %d, %d\n", r.Y1, r.Y2, r.X1, r.X2, r.Z)
for a.Y = r.Y2; a.Y >= r.Y1; a.Y-- { for a.Y = r.Y2; a.Y >= r.Y1; a.Y-- {
b.Y = a.Y b.Y = a.Y
from, to := common.CoordToPlain(a), common.CoordToPlain(b) // The keys in the database are stored and ordered as strings
it.Seek(common.StringToBytes(from)) // "1", "10", ..., "19", "2", "20", "21" so you cannot use
for ; it.Valid(); it.Next() { // an iterator and assume it is numerical ordered.
key := it.Key() // Each block is fetched with a Get instead.
var pos int64 for f, t := common.CoordToPlain(a), common.CoordToPlain(b); f <= t; f++ {
if pos, err = common.DecodeStringFromBytes(key); err != nil { key := common.StringToBytes(f)
log.Printf("decoding key failed: %s\n", err) value, err := ldbs.backend.db.Get(ro, key)
if err != nil {
log.Printf("get failed: %s\n", err)
return return
} }
if pos > to { if value != nil {
break select {
} case blocks <- Block{Key: key, Data: value}:
select { case <-done:
case blocks <- Block{Key: key, Data: it.Value()}: return
case <-done: }
return
} }
} }
if err = it.GetError(); err != nil {
log.Printf("iterating failed: %s\n", err)
return
}
} }
} }
}() }()