|
|
@ -111,10 +111,10 @@ pub enum IteratorMode<'a> { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl DBIterator { |
|
|
|
impl DBIterator { |
|
|
|
fn new<'b>(db: &DB, |
|
|
|
fn new(db: &DB, |
|
|
|
readopts: &'b ReadOptions, |
|
|
|
readopts: &ReadOptions, |
|
|
|
mode: IteratorMode) |
|
|
|
mode: IteratorMode) |
|
|
|
-> DBIterator { |
|
|
|
-> DBIterator { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
let iterator = rocksdb_ffi::rocksdb_create_iterator(db.inner, |
|
|
|
let iterator = rocksdb_ffi::rocksdb_create_iterator(db.inner, |
|
|
|
readopts.inner); |
|
|
|
readopts.inner); |
|
|
@ -274,13 +274,8 @@ impl DB { |
|
|
|
let cpath_ptr = cpath.as_ptr(); |
|
|
|
let cpath_ptr = cpath.as_ptr(); |
|
|
|
|
|
|
|
|
|
|
|
let ospath = Path::new(path); |
|
|
|
let ospath = Path::new(path); |
|
|
|
match fs::create_dir_all(&ospath) { |
|
|
|
if let Err(e) = fs::create_dir_all(&ospath) { |
|
|
|
Err(e) => { |
|
|
|
return Err(format!("Failed to create rocksdb directory: {:?}", e)) |
|
|
|
return Err(format!("Failed to create rocksdb directory: \ |
|
|
|
|
|
|
|
{:?}", |
|
|
|
|
|
|
|
e)) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
Ok(_) => (), |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
|
let mut err: *const i8 = 0 as *const i8; |
|
|
@ -337,7 +332,7 @@ impl DB { |
|
|
|
copts, handles, err_ptr); |
|
|
|
copts, handles, err_ptr); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
for handle in cfhandles.iter() { |
|
|
|
for handle in &cfhandles { |
|
|
|
if handle.0.is_null() { |
|
|
|
if handle.0.is_null() { |
|
|
|
return Err("Received null column family handle from DB." |
|
|
|
return Err("Received null column family handle from DB." |
|
|
|
.to_string()); |
|
|
|
.to_string()); |
|
|
@ -411,7 +406,7 @@ impl DB { |
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
return Ok(()); |
|
|
|
Ok(()) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
pub fn write(&self, batch: WriteBatch) -> Result<(), String> { |
|
|
|
pub fn write(&self, batch: WriteBatch) -> Result<(), String> { |
|
|
@ -445,9 +440,10 @@ impl DB { |
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
match val.is_null() { |
|
|
|
if val.is_null() { |
|
|
|
true => Ok(None), |
|
|
|
Ok(None) |
|
|
|
false => Ok(Some(DBVector::from_c(val, val_len))), |
|
|
|
} else { |
|
|
|
|
|
|
|
Ok(Some(DBVector::from_c(val, val_len))) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -485,9 +481,10 @@ impl DB { |
|
|
|
if !err.is_null() { |
|
|
|
if !err.is_null() { |
|
|
|
return Err(error_message(err)); |
|
|
|
return Err(error_message(err)); |
|
|
|
} |
|
|
|
} |
|
|
|
match val.is_null() { |
|
|
|
if val.is_null() { |
|
|
|
true => Ok(None), |
|
|
|
Ok(None) |
|
|
|
false => Ok(Some(DBVector::from_c(val, val_len))), |
|
|
|
} else { |
|
|
|
|
|
|
|
Ok(Some(DBVector::from_c(val, val_len))) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -750,7 +747,7 @@ impl Drop for WriteBatch { |
|
|
|
impl Drop for DB { |
|
|
|
impl Drop for DB { |
|
|
|
fn drop(&mut self) { |
|
|
|
fn drop(&mut self) { |
|
|
|
unsafe { |
|
|
|
unsafe { |
|
|
|
for (_, cf) in self.cfs.iter() { |
|
|
|
for cf in self.cfs.values() { |
|
|
|
rocksdb_ffi::rocksdb_column_family_handle_destroy(*cf); |
|
|
|
rocksdb_ffi::rocksdb_column_family_handle_destroy(*cf); |
|
|
|
} |
|
|
|
} |
|
|
|
rocksdb_ffi::rocksdb_close(self.inner); |
|
|
|
rocksdb_ffi::rocksdb_close(self.inner); |
|
|
@ -891,7 +888,7 @@ impl DBVector { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
pub fn to_utf8<'a>(&'a self) -> Option<&'a str> { |
|
|
|
pub fn to_utf8(&self) -> Option<&str> { |
|
|
|
from_utf8(self.deref()).ok() |
|
|
|
from_utf8(self.deref()).ok() |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|