mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-02-04 04:06:29 +00:00
Boog900
fdd1689665
Some checks failed
CI / ci (ubuntu-latest, stable, bash) (push) Has been cancelled
Deny / audit (push) Has been cancelled
Doc / build (push) Has been cancelled
Audit / audit (push) Has been cancelled
CI / fmt (push) Has been cancelled
CI / typo (push) Has been cancelled
CI / ci (macos-latest, stable, bash) (push) Has been cancelled
CI / ci (windows-latest, stable-x86_64-pc-windows-gnu, msys2 {0}) (push) Has been cancelled
Doc / deploy (push) Has been cancelled
* split the DB service abstraction * fix ci * misc changes * init tx-pool DBs * add some comments * move more types to `/types` * add some ops * add config & more ops functions & open function * add read & write svcs * add more docs * add write functions + docs * fix merge * fix test * fix ci * move `TxPoolWriteError` * add more docs * fix toml formatting * fix some docs * fix clippy * review fixes * update docs * fix merge * fix docs * fix tests * fix tests * add back lints * Update storage/txpool/README.md Co-authored-by: hinto-janai <hinto.janai@protonmail.com> --------- Co-authored-by: hinto-janai <hinto.janai@protonmail.com>
62 lines
2.3 KiB
Rust
62 lines
2.3 KiB
Rust
//! General free functions (related to the tx-pool database).
|
|
|
|
//---------------------------------------------------------------------------------------------------- Import
|
|
use cuprate_database::{ConcreteEnv, Env, EnvInner, InitError, RuntimeError, TxRw};
|
|
|
|
use crate::{config::Config, tables::OpenTables};
|
|
|
|
//---------------------------------------------------------------------------------------------------- Free functions
|
|
/// Open the txpool database using the passed [`Config`].
|
|
///
|
|
/// This calls [`cuprate_database::Env::open`] and prepares the
|
|
/// database to be ready for txpool-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)
|
|
}
|