Using generic types to specify column families when opening database...

master
Jordan Terrell 6 years ago
parent 13be813880
commit d00e03f72a
  1. 32
      src/db.rs
  2. 33
      tests/test_column_family.rs

@ -22,6 +22,7 @@ use std::collections::BTreeMap;
use std::ffi::{CStr, CString}; use std::ffi::{CStr, CString};
use std::fmt; use std::fmt;
use std::fs; use std::fs;
use std::iter;
use std::marker::PhantomData; use std::marker::PhantomData;
use std::ops::Deref; use std::ops::Deref;
use std::path::Path; use std::path::Path;
@ -660,28 +661,37 @@ impl DB {
/// Open the database with the specified options. /// Open the database with the specified options.
pub fn open<P: AsRef<Path>>(opts: &Options, path: P) -> Result<DB, Error> { pub fn open<P: AsRef<Path>>(opts: &Options, path: P) -> Result<DB, Error> {
DB::open_cf(opts, path, &[]) DB::open_cf(opts, path, iter::empty::<&str>())
} }
/// Open a database with the given database options and column family names. /// Open a database with the given database options and column family names.
/// ///
/// Column families opened using this function will be created with default `Options`. /// Column families opened using this function will be created with default `Options`.
pub fn open_cf<P: AsRef<Path>>(opts: &Options, path: P, cfs: &[&str]) -> Result<DB, Error> { pub fn open_cf<P, I, N>(opts: &Options, path: P, cfs: I) -> Result<DB, Error>
let cfs_v = cfs where P: AsRef<Path>,
.to_vec() I: IntoIterator<Item = N>,
.iter() N: AsRef<str> {
.map(|name| ColumnFamilyDescriptor::new(*name, Options::default()))
.collect(); let cfs = cfs
.into_iter()
.map(|name| ColumnFamilyDescriptor::new(name.as_ref(), Options::default()));
DB::open_cf_descriptors(opts, path, cfs_v) DB::open_cf_descriptors(opts, path, cfs)
} }
/// Open a database with the given database options and column family names/options. /// Open a database with the given database options and column family names/options.
pub fn open_cf_descriptors<P: AsRef<Path>>( pub fn open_cf_descriptors<P, I>(
opts: &Options, opts: &Options,
path: P, path: P,
cfs: Vec<ColumnFamilyDescriptor>, cfs: I,
) -> Result<DB, Error> { ) -> Result<DB, Error>
where P: AsRef<Path>,
I: IntoIterator<Item = ColumnFamilyDescriptor> {
let cfs: Vec<_> = cfs
.into_iter()
.collect();
let path = path.as_ref(); let path = path.as_ref();
let cpath = match CString::new(path.to_string_lossy().as_bytes()) { let cpath = match CString::new(path.to_string_lossy().as_bytes()) {
Ok(c) => c, Ok(c) => c,

@ -19,7 +19,7 @@ use rocksdb::{ColumnFamilyDescriptor, MergeOperands, Options, DB};
use util::DBPath; use util::DBPath;
#[test] #[test]
pub fn test_column_family() { fn test_column_family() {
let n = DBPath::new("_rust_rocksdb_cftest"); let n = DBPath::new("_rust_rocksdb_cftest");
// should be able to create column families // should be able to create column families
@ -88,6 +88,35 @@ pub fn test_column_family() {
} }
} }
#[test]
fn test_can_open_db_with_results_of_list_cf() {
// Test scenario derived from GitHub issue #175 and 177
let n = DBPath::new("_rust_rocksdb_cftest_with_list_cf");
{
let mut opts = Options::default();
opts.create_if_missing(true);
let db = DB::open(&opts, &n).unwrap();
let opts = Options::default();
match db.create_cf("cf1", &opts) {
Ok(_db) => println!("cf1 created successfully"),
Err(e) => {
panic!("could not create column family: {}", e);
}
}
}
{
let options = Options::default();
let cfs = DB::list_cf(&options, &n).unwrap();
let db = DB::open_cf(&options, &n, &cfs).unwrap();
assert!(db.cf_handle("cf1").is_some());
}
}
#[test] #[test]
fn test_create_missing_column_family() { fn test_create_missing_column_family() {
let n = DBPath::new("_rust_rocksdb_missing_cftest"); let n = DBPath::new("_rust_rocksdb_missing_cftest");
@ -172,7 +201,7 @@ fn test_provided_merge(
} }
#[test] #[test]
pub fn test_column_family_with_options() { fn test_column_family_with_options() {
let n = DBPath::new("_rust_rocksdb_cf_with_optionstest"); let n = DBPath::new("_rust_rocksdb_cf_with_optionstest");
{ {
let mut cfopts = Options::default(); let mut cfopts = Options::default();

Loading…
Cancel
Save