mirror of
https://github.com/Cuprate/cuprate.git
synced 2024-12-23 03:59:31 +00:00
0a390a362a
Some checks are pending
CI / fmt (push) Waiting to run
CI / typo (push) Waiting to run
CI / ci (macos-latest, stable, bash) (push) Waiting to run
CI / ci (ubuntu-latest, stable, bash) (push) Waiting to run
CI / ci (windows-latest, stable-x86_64-pc-windows-gnu, msys2 {0}) (push) Waiting to run
Doc / build (push) Waiting to run
Doc / deploy (push) Blocked by required conditions
* database: doc fixes * blockchain: doc fixes * database: fix doc test * database: readme fixes * blockchain: ops fix * blockchain: readme fix
68 lines
2.5 KiB
Rust
68 lines
2.5 KiB
Rust
//! General free functions (related to the database).
|
|
|
|
//---------------------------------------------------------------------------------------------------- Import
|
|
use cuprate_database::{ConcreteEnv, Env, EnvInner, InitError, RuntimeError, TxRw};
|
|
|
|
use crate::{config::Config, 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().map_err(runtime_to_init_error)?;
|
|
|
|
// Create all tables.
|
|
OpenTables::create_tables(&env_inner, &tx_rw).map_err(runtime_to_init_error)?;
|
|
|
|
TxRw::commit(tx_rw).map_err(runtime_to_init_error)?;
|
|
}
|
|
|
|
Ok(env)
|
|
}
|
|
|
|
//---------------------------------------------------------------------------------------------------- Tests
|
|
#[cfg(test)]
|
|
mod test {
|
|
// use super::*;
|
|
}
|