|
|
@ -27,7 +27,7 @@ use std::str::from_utf8; |
|
|
|
use self::libc::{c_void, size_t}; |
|
|
|
use self::libc::{c_void, size_t}; |
|
|
|
|
|
|
|
|
|
|
|
use rocksdb_ffi::{self, DBCFHandle, error_message}; |
|
|
|
use rocksdb_ffi::{self, DBCFHandle, error_message}; |
|
|
|
use rocksdb_options::Options; |
|
|
|
use rocksdb_options::{Options, WriteOptions}; |
|
|
|
|
|
|
|
|
|
|
|
pub struct DB { |
|
|
|
pub struct DB { |
|
|
|
inner: rocksdb_ffi::DBInstance, |
|
|
|
inner: rocksdb_ffi::DBInstance, |
|
|
@ -381,16 +381,17 @@ impl DB { |
|
|
|
Ok(()) |
|
|
|
Ok(()) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
pub fn write(&self, batch: WriteBatch) -> Result<(), String> { |
|
|
|
pub fn write_opt(&self, |
|
|
|
let writeopts = unsafe { rocksdb_ffi::rocksdb_writeoptions_create() }; |
|
|
|
batch: WriteBatch, |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
rocksdb_ffi::rocksdb_write(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_write(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
batch.inner, |
|
|
|
batch.inner, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
@ -398,6 +399,10 @@ impl DB { |
|
|
|
return Ok(()); |
|
|
|
return Ok(()); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
pub fn write(&self, batch: WriteBatch) -> Result<(), String> { |
|
|
|
|
|
|
|
self.write_opt(batch, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
pub fn get(&self, key: &[u8]) -> Result<Option<DBVector>, String> { |
|
|
|
pub fn get(&self, key: &[u8]) -> Result<Option<DBVector>, String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let readopts = rocksdb_ffi::rocksdb_readoptions_create(); |
|
|
|
let readopts = rocksdb_ffi::rocksdb_readoptions_create(); |
|
|
@ -538,22 +543,22 @@ impl DB { |
|
|
|
pub fn snapshot(&self) -> Snapshot { |
|
|
|
pub fn snapshot(&self) -> Snapshot { |
|
|
|
Snapshot::new(self) |
|
|
|
Snapshot::new(self) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl Writable for DB { |
|
|
|
pub fn put_opt(&self, |
|
|
|
fn put(&self, key: &[u8], value: &[u8]) -> Result<(), String> { |
|
|
|
key: &[u8], |
|
|
|
|
|
|
|
value: &[u8], |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let writeopts = rocksdb_ffi::rocksdb_writeoptions_create(); |
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
rocksdb_ffi::rocksdb_put(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_put(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
key.as_ptr(), |
|
|
|
key.as_ptr(), |
|
|
|
key.len() as size_t, |
|
|
|
key.len() as size_t, |
|
|
|
value.as_ptr(), |
|
|
|
value.as_ptr(), |
|
|
|
value.len() as size_t, |
|
|
|
value.len() as size_t, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
@ -561,106 +566,105 @@ impl Writable for DB { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
fn put_cf(&self, |
|
|
|
pub fn put_cf_opt(&self, |
|
|
|
cf: DBCFHandle, |
|
|
|
cf: DBCFHandle, |
|
|
|
key: &[u8], |
|
|
|
key: &[u8], |
|
|
|
value: &[u8]) |
|
|
|
value: &[u8], |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
-> Result<(), String> { |
|
|
|
-> Result<(), String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let writeopts = rocksdb_ffi::rocksdb_writeoptions_create(); |
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
rocksdb_ffi::rocksdb_put_cf(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_put_cf(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
cf, |
|
|
|
cf, |
|
|
|
key.as_ptr(), |
|
|
|
key.as_ptr(), |
|
|
|
key.len() as size_t, |
|
|
|
key.len() as size_t, |
|
|
|
value.as_ptr(), |
|
|
|
value.as_ptr(), |
|
|
|
value.len() as size_t, |
|
|
|
value.len() as size_t, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
Ok(()) |
|
|
|
Ok(()) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
pub fn merge_opt(&self, |
|
|
|
fn merge(&self, key: &[u8], value: &[u8]) -> Result<(), String> { |
|
|
|
key: &[u8], |
|
|
|
|
|
|
|
value: &[u8], |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let writeopts = rocksdb_ffi::rocksdb_writeoptions_create(); |
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
rocksdb_ffi::rocksdb_merge(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_merge(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
key.as_ptr(), |
|
|
|
key.as_ptr(), |
|
|
|
key.len() as size_t, |
|
|
|
key.len() as size_t, |
|
|
|
value.as_ptr(), |
|
|
|
value.as_ptr(), |
|
|
|
value.len() as size_t, |
|
|
|
value.len() as size_t, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
Ok(()) |
|
|
|
Ok(()) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
fn merge_cf_opt(&self, |
|
|
|
fn merge_cf(&self, |
|
|
|
|
|
|
|
cf: DBCFHandle, |
|
|
|
cf: DBCFHandle, |
|
|
|
key: &[u8], |
|
|
|
key: &[u8], |
|
|
|
value: &[u8]) |
|
|
|
value: &[u8], |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
-> Result<(), String> { |
|
|
|
-> Result<(), String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let writeopts = rocksdb_ffi::rocksdb_writeoptions_create(); |
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
rocksdb_ffi::rocksdb_merge_cf(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_merge_cf(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
cf, |
|
|
|
cf, |
|
|
|
key.as_ptr(), |
|
|
|
key.as_ptr(), |
|
|
|
key.len() as size_t, |
|
|
|
key.len() as size_t, |
|
|
|
value.as_ptr(), |
|
|
|
value.as_ptr(), |
|
|
|
value.len() as size_t, |
|
|
|
value.len() as size_t, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
Ok(()) |
|
|
|
Ok(()) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
fn delete_opt(&self, |
|
|
|
fn delete(&self, key: &[u8]) -> Result<(), String> { |
|
|
|
key: &[u8], |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let writeopts = rocksdb_ffi::rocksdb_writeoptions_create(); |
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
rocksdb_ffi::rocksdb_delete(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_delete(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
key.as_ptr(), |
|
|
|
key.as_ptr(), |
|
|
|
key.len() as size_t, |
|
|
|
key.len() as size_t, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
Ok(()) |
|
|
|
Ok(()) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
fn delete_cf_opt(&self, |
|
|
|
fn delete_cf(&self, cf: DBCFHandle, key: &[u8]) -> Result<(), String> { |
|
|
|
cf: DBCFHandle, |
|
|
|
|
|
|
|
key: &[u8], |
|
|
|
|
|
|
|
writeopts: &WriteOptions) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let writeopts = rocksdb_ffi::rocksdb_writeoptions_create(); |
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
let err_ptr: *mut *const i8 = &mut err; |
|
|
|
rocksdb_ffi::rocksdb_delete_cf(self.inner, |
|
|
|
rocksdb_ffi::rocksdb_delete_cf(self.inner, |
|
|
|
writeopts.clone(), |
|
|
|
writeopts.inner, |
|
|
|
cf, |
|
|
|
cf, |
|
|
|
key.as_ptr(), |
|
|
|
key.as_ptr(), |
|
|
|
key.len() as size_t, |
|
|
|
key.len() as size_t, |
|
|
|
err_ptr); |
|
|
|
err_ptr); |
|
|
|
rocksdb_ffi::rocksdb_writeoptions_destroy(writeopts); |
|
|
|
|
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
@ -669,6 +673,40 @@ impl Writable for DB { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl Writable for DB { |
|
|
|
|
|
|
|
fn put(&self, key: &[u8], value: &[u8]) -> Result<(), String> { |
|
|
|
|
|
|
|
self.put_opt(key, value, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn put_cf(&self, |
|
|
|
|
|
|
|
cf: DBCFHandle, |
|
|
|
|
|
|
|
key: &[u8], |
|
|
|
|
|
|
|
value: &[u8]) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
|
|
|
|
self.put_cf_opt(cf, key, value, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn merge(&self, key: &[u8], value: &[u8]) -> Result<(), String> { |
|
|
|
|
|
|
|
self.merge_opt(key, value, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn merge_cf(&self, |
|
|
|
|
|
|
|
cf: DBCFHandle, |
|
|
|
|
|
|
|
key: &[u8], |
|
|
|
|
|
|
|
value: &[u8]) |
|
|
|
|
|
|
|
-> Result<(), String> { |
|
|
|
|
|
|
|
self.merge_cf_opt(cf, key, value, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn delete(&self, key: &[u8]) -> Result<(), String> { |
|
|
|
|
|
|
|
self.delete_opt(key, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn delete_cf(&self, cf: DBCFHandle, key: &[u8]) -> Result<(), String> { |
|
|
|
|
|
|
|
self.delete_cf_opt(cf, key, &WriteOptions::new()) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
impl WriteBatch { |
|
|
|
impl WriteBatch { |
|
|
|
pub fn new() -> WriteBatch { |
|
|
|
pub fn new() -> WriteBatch { |
|
|
|
WriteBatch { |
|
|
|
WriteBatch { |
|
|
|