ledisdb/vendor/gomdb/cursor.go

106 lines
2.1 KiB
Go
Raw Permalink Normal View History

// +build lmdb
package mdb
/*
#cgo CFLAGS: -pthread -W -Wall -Wno-unused-parameter -Wbad-function-cast -O2 -g
#cgo freebsd CFLAGS: -DMDB_DSYNC=O_SYNC
#cgo openbsd CFLAGS: -DMDB_DSYNC=O_SYNC
#cgo netbsd CFLAGS: -DMDB_DSYNC=O_SYNC
#include <stdlib.h>
#include <stdio.h>
#include "lmdb.h"
*/
import "C"
import (
"errors"
)
// MDB_cursor_op
const (
FIRST = iota
FIRST_DUP
GET_BOTH
GET_RANGE
GET_CURRENT
GET_MULTIPLE
LAST
LAST_DUP
NEXT
NEXT_DUP
NEXT_MULTIPLE
NEXT_NODUP
PREV
PREV_DUP
PREV_NODUP
SET
SET_KEY
SET_RANGE
)
func (cursor *Cursor) Close() error {
if cursor._cursor == nil {
return errors.New("Cursor already closed")
}
C.mdb_cursor_close(cursor._cursor)
cursor._cursor = nil
return nil
}
func (cursor *Cursor) Txn() *Txn {
var _txn *C.MDB_txn
_txn = C.mdb_cursor_txn(cursor._cursor)
if _txn != nil {
return &Txn{_txn}
}
return nil
}
func (cursor *Cursor) DBI() DBI {
var _dbi C.MDB_dbi
_dbi = C.mdb_cursor_dbi(cursor._cursor)
return DBI(_dbi)
}
// Retrieves the low-level MDB cursor.
func (cursor *Cursor) MdbCursor() *C.MDB_cursor {
return cursor._cursor
}
func (cursor *Cursor) Get(set_key, sval []byte, op uint) (key, val []byte, err error) {
k, v, err := cursor.GetVal(set_key, sval, op)
if err != nil {
return nil, nil, err
}
return k.Bytes(), v.Bytes(), nil
}
func (cursor *Cursor) GetVal(key, val []byte, op uint) (Val, Val, error) {
ckey := Wrap(key)
cval := Wrap(val)
ret := C.mdb_cursor_get(cursor._cursor, (*C.MDB_val)(&ckey), (*C.MDB_val)(&cval), C.MDB_cursor_op(op))
return ckey, cval, errno(ret)
}
func (cursor *Cursor) Put(key, val []byte, flags uint) error {
ckey := Wrap(key)
cval := Wrap(val)
ret := C.mdb_cursor_put(cursor._cursor, (*C.MDB_val)(&ckey), (*C.MDB_val)(&cval), C.uint(flags))
return errno(ret)
}
func (cursor *Cursor) Del(flags uint) error {
ret := C.mdb_cursor_del(cursor._cursor, C.uint(flags))
return errno(ret)
}
func (cursor *Cursor) Count() (uint64, error) {
var _size C.size_t
ret := C.mdb_cursor_count(cursor._cursor, &_size)
if ret != SUCCESS {
return 0, errno(ret)
}
return uint64(_size), nil
}