Add support for writebatch

master
David Greenberg 10 years ago
parent f2c6fc5a27
commit a0f3ad3aa4
  1. 4
      src/ffi.rs
  2. 1
      src/lib.rs
  3. 88
      src/rocksdb.rs

@ -272,6 +272,10 @@ extern {
pub fn rocksdb_iter_get_error(iter: RocksDBIterator, pub fn rocksdb_iter_get_error(iter: RocksDBIterator,
err: *const *const u8); err: *const *const u8);
// Write batch // Write batch
pub fn rocksdb_write(db: RocksDBInstance,
writeopts: RocksDBWriteOptions,
batch : RocksDBWriteBatch,
err: *mut i8);
pub fn rocksdb_writebatch_create() -> RocksDBWriteBatch; pub fn rocksdb_writebatch_create() -> RocksDBWriteBatch;
pub fn rocksdb_writebatch_create_from(rep: *const u8, pub fn rocksdb_writebatch_create_from(rep: *const u8,
size: size_t) -> RocksDBWriteBatch; size: size_t) -> RocksDBWriteBatch;

@ -34,6 +34,7 @@ pub use rocksdb::{
RocksDB, RocksDB,
RocksDBResult, RocksDBResult,
RocksDBVector, RocksDBVector,
WriteBatch,
Writable, Writable,
}; };
pub use rocksdb_options::{ pub use rocksdb_options::{

@ -128,11 +128,17 @@ impl RocksDB {
} }
} }
////pub fn create_writebatch(self) -> WriteBatch { pub fn write(&self, batch: WriteBatch) -> Result<(), &str> {
//// WriteBatch(unsafe { unsafe {
//// rocksdb_ffi::rocksdb_writebatch_create() let writeopts = rocksdb_ffi::rocksdb_writeoptions_create();
//// }) let err = 0 as *mut i8;
////} rocksdb_ffi::rocksdb_write(self.inner, writeopts, batch.inner, err);
if !err.is_null() {
return Err(error_message(err));
}
return Ok(())
}
}
pub fn get(&self, key: &[u8]) -> RocksDBResult<RocksDBVector, &str> { pub fn get(&self, key: &[u8]) -> RocksDBResult<RocksDBVector, &str> {
unsafe { unsafe {
@ -209,6 +215,52 @@ impl Writable for RocksDB {
} }
} }
impl WriteBatch {
pub fn new() -> WriteBatch {
WriteBatch {
inner: unsafe {
rocksdb_ffi::rocksdb_writebatch_create()
}
}
}
}
impl Drop for WriteBatch {
fn drop(&mut self) {
unsafe {
rocksdb_ffi::rocksdb_writebatch_destroy(self.inner)
}
}
}
impl Writable for WriteBatch {
fn put(&self, key: &[u8], value: &[u8]) -> Result<(), &str> {
unsafe {
rocksdb_ffi::rocksdb_writebatch_put(self.inner, key.as_ptr(),
key.len() as size_t, value.as_ptr(),
value.len() as size_t);
return Ok(())
}
}
fn merge(&self, key: &[u8], value: &[u8]) -> Result<(), &str> {
unsafe {
rocksdb_ffi::rocksdb_writebatch_merge(self.inner, key.as_ptr(),
key.len() as size_t, value.as_ptr(),
value.len() as size_t);
return Ok(())
}
}
fn delete(&self, key: &[u8]) -> Result<(),&str> {
unsafe {
rocksdb_ffi::rocksdb_writebatch_delete(self.inner, key.as_ptr(),
key.len() as size_t);
return Ok(())
}
}
}
pub struct RocksDBVector { pub struct RocksDBVector {
base: Unique<u8>, base: Unique<u8>,
len: usize, len: usize,
@ -329,3 +381,29 @@ fn external() {
let opts = RocksDBOptions::new(); let opts = RocksDBOptions::new();
assert!(RocksDB::destroy(opts, path).is_ok()); assert!(RocksDB::destroy(opts, path).is_ok());
} }
#[test]
fn writebatch_works() {
let path = "_rust_rocksdb_writebacktest";
let db = RocksDB::open_default(path).unwrap();
{ // test put
let batch = WriteBatch::new();
assert!(db.get(b"k1").is_none());
batch.put(b"k1", b"v1111");
assert!(db.get(b"k1").is_none());
let p = db.write(batch);
assert!(p.is_ok());
let r: RocksDBResult<RocksDBVector, &str> = db.get(b"k1");
assert!(r.unwrap().to_utf8().unwrap() == "v1111");
}
{ // test delete
let batch = WriteBatch::new();
batch.delete(b"k1");
let p = db.write(batch);
assert!(p.is_ok());
assert!(db.get(b"k1").is_none());
}
db.close();
let opts = RocksDBOptions::new();
assert!(RocksDB::destroy(opts, path).is_ok());
}

Loading…
Cancel
Save