use crate::{plumbing::DatabaseStorageTypes, Runtime}; use triomphe::Arc; /// Stores the cached results and dependency information for all the queries /// defined on your salsa database. Also embeds a [`Runtime`] which is used to /// manage query execution. Every database must include a `storage: /// Storage` field. pub struct Storage { query_store: Arc, runtime: Runtime, } impl Default for Storage { fn default() -> Self { Self { query_store: Default::default(), runtime: Default::default() } } } impl Storage { /// Gives access to the underlying salsa runtime. pub fn salsa_runtime(&self) -> &Runtime { &self.runtime } /// Gives access to the underlying salsa runtime. pub fn salsa_runtime_mut(&mut self) -> &mut Runtime { &mut self.runtime } /// Access the query storage tables. Not meant to be used directly by end /// users. pub fn query_store(&self) -> &DB::DatabaseStorage { &self.query_store } /// Access the query storage tables. Not meant to be used directly by end /// users. pub fn query_store_mut(&mut self) -> (&DB::DatabaseStorage, &mut Runtime) { (&self.query_store, &mut self.runtime) } /// Returns a "snapshotted" storage, suitable for use in a forked database. /// This snapshot hold a read-lock on the global state, which means that any /// attempt to `set` an input will block until the forked runtime is /// dropped. See `ParallelDatabase::snapshot` for more information. /// /// **Warning.** This second handle is intended to be used from a separate /// thread. Using two database handles from the **same thread** can lead to /// deadlock. pub fn snapshot(&self) -> Self { Storage { query_store: self.query_store.clone(), runtime: self.runtime.snapshot() } } }