mirror of
https://github.com/Cuprate/cuprate.git
synced 2025-01-13 06:14:33 +00:00
a438279aa8
* storage: port some code `cuprate-blockchain` -> `database` * database: remove `Tables` references * database: remove old `cuprate-blockchain` type references * find/replace `cuprate_blockchain` -> `database`, add `create_db()` * database: fix redb * database: use readme for docs, link in `lib.rs` * database: fix `open_db_ro`, `open_db_rw`, `create_db` behavior * database: add open table tests * database: fix tests, remove blockchain specific references * database: remove `ReaderThreads`, make `db_directory` mandatory * initial `cuprate-blockchain` split * fix doc links * rename, fix database config * blockchain: create `crate::open()`, `OpenTables::create_tables()` * more compat fixes * fix imports * fix conflicts * align cargo.toml * docs * fixes * add `unused_crate_dependencies` lint, fix * blockchain: add open table tests
76 lines
2.6 KiB
Rust
76 lines
2.6 KiB
Rust
//! General free functions (related to the database).
|
|
|
|
//---------------------------------------------------------------------------------------------------- Import
|
|
use cuprate_database::{ConcreteEnv, Env, EnvInner, InitError, RuntimeError, TxRw};
|
|
|
|
use crate::{config::Config, open_tables::OpenTables};
|
|
|
|
//---------------------------------------------------------------------------------------------------- Free functions
|
|
/// Open the blockchain database, using the passed [`Config`].
|
|
///
|
|
/// This calls [`cuprate_database::Env::open`] and prepares the
|
|
/// database to be ready for blockchain-related usage, e.g.
|
|
/// table creation, table sort order, etc.
|
|
///
|
|
/// All tables found in [`crate::tables`] will be
|
|
/// ready for usage in the returned [`ConcreteEnv`].
|
|
///
|
|
/// # Errors
|
|
/// This will error if:
|
|
/// - The database file could not be opened
|
|
/// - A write transaction could not be opened
|
|
/// - A table could not be created/opened
|
|
#[cold]
|
|
#[inline(never)] // only called once
|
|
pub fn open(config: Config) -> Result<ConcreteEnv, InitError> {
|
|
// Attempt to open the database environment.
|
|
let env = <ConcreteEnv as Env>::open(config.db_config)?;
|
|
|
|
/// Convert runtime errors to init errors.
|
|
///
|
|
/// INVARIANT:
|
|
/// `cuprate_database`'s functions mostly return the former
|
|
/// so we must convert them. We have knowledge of which errors
|
|
/// makes sense in this functions context so we panic on
|
|
/// unexpected ones.
|
|
fn runtime_to_init_error(runtime: RuntimeError) -> InitError {
|
|
match runtime {
|
|
RuntimeError::Io(io_error) => io_error.into(),
|
|
|
|
// These errors shouldn't be happening here.
|
|
RuntimeError::KeyExists
|
|
| RuntimeError::KeyNotFound
|
|
| RuntimeError::ResizeNeeded
|
|
| RuntimeError::TableNotFound => unreachable!(),
|
|
}
|
|
}
|
|
|
|
// INVARIANT: We must ensure that all tables are created,
|
|
// `cuprate_database` has no way of knowing _which_ tables
|
|
// we want since it is agnostic, so we are responsible for this.
|
|
{
|
|
let env_inner = env.env_inner();
|
|
let tx_rw = env_inner.tx_rw();
|
|
let tx_rw = match tx_rw {
|
|
Ok(tx_rw) => tx_rw,
|
|
Err(e) => return Err(runtime_to_init_error(e)),
|
|
};
|
|
|
|
// Create all tables.
|
|
if let Err(e) = OpenTables::create_tables(&env_inner, &tx_rw) {
|
|
return Err(runtime_to_init_error(e));
|
|
};
|
|
|
|
if let Err(e) = tx_rw.commit() {
|
|
return Err(runtime_to_init_error(e));
|
|
}
|
|
}
|
|
|
|
Ok(env)
|
|
}
|
|
|
|
//---------------------------------------------------------------------------------------------------- Tests
|
|
#[cfg(test)]
|
|
mod test {
|
|
// use super::*;
|
|
}
|