ledisdb/store/leveldb/batch.go

105 lines
2.1 KiB
Go
Raw Normal View History

2014-07-25 13:58:00 +04:00
// +build leveldb
2014-06-19 13:19:40 +04:00
package leveldb
// #cgo LDFLAGS: -lleveldb
// #include "leveldb/c.h"
2014-11-10 16:43:25 +03:00
// #include "leveldb_ext.h"
2014-06-19 13:19:40 +04:00
import "C"
import (
2014-11-20 17:52:29 +03:00
"github.com/syndtr/goleveldb/leveldb"
2014-06-19 13:19:40 +04:00
"unsafe"
)
type WriteBatch struct {
db *DB
wbatch *C.leveldb_writebatch_t
gbatch *leveldb.Batch
}
func newWriteBatch(db *DB) *WriteBatch {
w := new(WriteBatch)
w.db = db
w.wbatch = C.leveldb_writebatch_create()
w.gbatch = new(leveldb.Batch)
return w
2014-06-19 13:19:40 +04:00
}
2014-11-10 10:31:36 +03:00
func (w *WriteBatch) Close() {
if w.wbatch != nil {
C.leveldb_writebatch_destroy(w.wbatch)
w.wbatch = nil
}
w.gbatch = nil
2014-06-19 13:19:40 +04:00
}
func (w *WriteBatch) Put(key, value []byte) {
var k, v *C.char
if len(key) != 0 {
k = (*C.char)(unsafe.Pointer(&key[0]))
}
if len(value) != 0 {
v = (*C.char)(unsafe.Pointer(&value[0]))
}
lenk := len(key)
lenv := len(value)
C.leveldb_writebatch_put(w.wbatch, k, C.size_t(lenk), v, C.size_t(lenv))
}
func (w *WriteBatch) Delete(key []byte) {
C.leveldb_writebatch_delete(w.wbatch,
(*C.char)(unsafe.Pointer(&key[0])), C.size_t(len(key)))
}
func (w *WriteBatch) Commit() error {
return w.commit(w.db.writeOpts)
}
2014-10-09 09:05:55 +04:00
func (w *WriteBatch) SyncCommit() error {
return w.commit(w.db.syncOpts)
}
2014-07-25 13:58:00 +04:00
func (w *WriteBatch) Rollback() error {
2014-06-19 13:19:40 +04:00
C.leveldb_writebatch_clear(w.wbatch)
2014-07-25 13:58:00 +04:00
return nil
2014-06-19 13:19:40 +04:00
}
func (w *WriteBatch) commit(wb *WriteOptions) error {
var errStr *C.char
C.leveldb_write(w.db.db, wb.Opt, w.wbatch, &errStr)
if errStr != nil {
return saveError(errStr)
}
return nil
}
2014-11-10 16:43:25 +03:00
//export leveldb_writebatch_iterate_put
func leveldb_writebatch_iterate_put(p unsafe.Pointer, k *C.char, klen C.size_t, v *C.char, vlen C.size_t) {
b := (*leveldb.Batch)(p)
key := slice(unsafe.Pointer(k), int(klen))
value := slice(unsafe.Pointer(v), int(vlen))
b.Put(key, value)
}
//export leveldb_writebatch_iterate_delete
func leveldb_writebatch_iterate_delete(p unsafe.Pointer, k *C.char, klen C.size_t) {
b := (*leveldb.Batch)(p)
key := slice(unsafe.Pointer(k), int(klen))
b.Delete(key)
}
func (w *WriteBatch) Data() []byte {
2014-11-10 16:43:25 +03:00
w.gbatch.Reset()
C.leveldb_writebatch_iterate_ext(w.wbatch,
unsafe.Pointer(w.gbatch))
b := w.gbatch.Dump()
return b
}