use crate::config::Config; use rusqlite::{Connection, Result}; use std::collections::HashMap; use tetratto_l10n::{LangFile, read_langs}; #[derive(Clone)] pub struct DataManager(pub Config, pub HashMap); impl DataManager { /// Obtain a connection to the staging database. pub(crate) async fn connect(&self) -> Result { Ok(Connection::open(&self.0.database.name)?) } /// Create a new [`DataManager`] (and init database). pub async fn new(config: Config) -> Result { let this = Self(config.clone(), read_langs()); let conn = this.connect().await?; conn.pragma_update(None, "journal_mode", "WAL").unwrap(); Ok(this) } } #[cfg(feature = "sqlite")] #[macro_export] macro_rules! get { ($row:ident->$idx:literal($t:tt)) => { $row.get::($idx).unwrap() }; } #[macro_export] macro_rules! query_row { ($conn:expr, $sql:expr, $params:expr, $f:expr) => {{ let mut query = $conn.prepare($sql).unwrap(); query.query_row($params, $f) }}; } #[macro_export] macro_rules! execute { ($conn:expr, $sql:expr, $params:expr) => { $conn.prepare($sql).unwrap().execute($params) }; }