2014-10-31 14:42:32 +01:00
|
|
|
// Copyright (c) 2014 Couchbase, Inc.
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
|
|
|
|
// except in compliance with the License. You may obtain a copy of the License at
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
// Unless required by applicable law or agreed to in writing, software distributed under the
|
|
|
|
// License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
|
|
// either express or implied. See the License for the specific language governing permissions
|
|
|
|
// and limitations under the License.
|
|
|
|
|
|
|
|
// +build forestdb
|
|
|
|
|
|
|
|
package forestdb
|
|
|
|
|
|
|
|
import (
|
2015-04-24 23:35:01 +02:00
|
|
|
"github.com/couchbase/goforestdb"
|
2014-10-31 14:42:32 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type Iterator struct {
|
|
|
|
store *Store
|
2014-11-26 03:52:35 +01:00
|
|
|
snapshot *forestdb.KVStore
|
2014-10-31 14:42:32 +01:00
|
|
|
iterator *forestdb.Iterator
|
|
|
|
curr *forestdb.Doc
|
|
|
|
valid bool
|
|
|
|
}
|
|
|
|
|
|
|
|
func newIterator(store *Store) *Iterator {
|
2014-11-26 03:52:35 +01:00
|
|
|
itr, err := store.dbkv.IteratorInit([]byte{}, nil, forestdb.ITR_NONE)
|
2014-10-31 14:42:32 +01:00
|
|
|
rv := Iterator{
|
|
|
|
store: store,
|
|
|
|
iterator: itr,
|
|
|
|
valid: err == nil,
|
|
|
|
}
|
|
|
|
return &rv
|
|
|
|
}
|
|
|
|
|
2014-11-26 03:52:35 +01:00
|
|
|
func newIteratorWithSnapshot(store *Store, snapshot *forestdb.KVStore) *Iterator {
|
2014-10-31 14:42:32 +01:00
|
|
|
itr, err := snapshot.IteratorInit([]byte{}, nil, forestdb.ITR_NONE)
|
|
|
|
rv := Iterator{
|
|
|
|
store: store,
|
|
|
|
iterator: itr,
|
|
|
|
valid: err == nil,
|
|
|
|
}
|
|
|
|
return &rv
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) SeekFirst() {
|
2014-12-27 22:15:14 +01:00
|
|
|
err := i.iterator.SeekMin()
|
|
|
|
if err != nil {
|
|
|
|
i.valid = false
|
|
|
|
return
|
|
|
|
}
|
2015-04-24 23:48:21 +02:00
|
|
|
if i.curr != nil {
|
|
|
|
i.curr.Close()
|
|
|
|
}
|
2014-12-27 22:15:14 +01:00
|
|
|
i.curr, err = i.iterator.Get()
|
|
|
|
if err != nil {
|
|
|
|
i.valid = false
|
|
|
|
}
|
2014-10-31 14:42:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Seek(key []byte) {
|
2014-12-27 22:15:14 +01:00
|
|
|
err := i.iterator.Seek(key, forestdb.FDB_ITR_SEEK_HIGHER)
|
|
|
|
if err != nil {
|
|
|
|
i.valid = false
|
|
|
|
return
|
|
|
|
}
|
2015-04-24 23:48:21 +02:00
|
|
|
if i.curr != nil {
|
|
|
|
i.curr.Close()
|
|
|
|
}
|
2014-12-27 22:15:14 +01:00
|
|
|
i.curr, err = i.iterator.Get()
|
|
|
|
if err != nil {
|
|
|
|
i.valid = false
|
|
|
|
return
|
|
|
|
}
|
2014-10-31 14:42:32 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Next() {
|
2014-12-27 22:15:14 +01:00
|
|
|
err := i.iterator.Next()
|
|
|
|
if err != nil {
|
|
|
|
i.valid = false
|
|
|
|
return
|
|
|
|
}
|
2015-04-24 23:48:21 +02:00
|
|
|
if i.curr != nil {
|
|
|
|
i.curr.Close()
|
|
|
|
}
|
2014-12-27 22:15:14 +01:00
|
|
|
i.curr, err = i.iterator.Get()
|
2014-10-31 14:42:32 +01:00
|
|
|
if err != nil {
|
|
|
|
i.valid = false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Current() ([]byte, []byte, bool) {
|
|
|
|
if i.Valid() {
|
|
|
|
return i.Key(), i.Value(), true
|
|
|
|
}
|
|
|
|
return nil, nil, false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Key() []byte {
|
|
|
|
return i.curr.Key()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Value() []byte {
|
|
|
|
return i.curr.Body()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Valid() bool {
|
|
|
|
return i.valid
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *Iterator) Close() error {
|
|
|
|
i.valid = false
|
2015-04-24 23:48:21 +02:00
|
|
|
if i.curr != nil {
|
|
|
|
i.curr.Close()
|
|
|
|
}
|
2014-10-31 14:42:32 +01:00
|
|
|
return i.iterator.Close()
|
|
|
|
}
|