mirror of
https://github.com/salsa-rs/salsa.git
synced 2025-01-23 13:10:19 +00:00
64556e9d28
Creating events if nobody is listening has always bugged me.
51 lines
1.3 KiB
Rust
51 lines
1.3 KiB
Rust
use std::sync::{Arc, Mutex};
|
|
|
|
// ANCHOR: db_struct
|
|
#[derive(Default)]
|
|
#[salsa::db]
|
|
pub(crate) struct Database {
|
|
storage: salsa::Storage<Self>,
|
|
|
|
// The logs are only used for testing and demonstrating reuse:
|
|
//
|
|
logs: Option<Arc<Mutex<Vec<String>>>>,
|
|
}
|
|
// ANCHOR_END: db_struct
|
|
|
|
impl Database {
|
|
/// Enable logging of each salsa event.
|
|
#[cfg(test)]
|
|
pub fn enable_logging(self) -> Self {
|
|
assert!(self.logs.is_none());
|
|
Self {
|
|
storage: self.storage,
|
|
logs: Some(Default::default()),
|
|
}
|
|
}
|
|
|
|
#[cfg(test)]
|
|
pub fn take_logs(&mut self) -> Vec<String> {
|
|
if let Some(logs) = &self.logs {
|
|
std::mem::take(&mut *logs.lock().unwrap())
|
|
} else {
|
|
panic!("logs not enabled");
|
|
}
|
|
}
|
|
}
|
|
|
|
// ANCHOR: db_impl
|
|
#[salsa::db]
|
|
impl salsa::Database for Database {
|
|
fn salsa_event(&self, event: &dyn Fn() -> salsa::Event) {
|
|
let event = event();
|
|
eprintln!("Event: {event:?}");
|
|
// Log interesting events, if logging is enabled
|
|
if let Some(logs) = &self.logs {
|
|
// don't log boring events
|
|
if let salsa::EventKind::WillExecute { .. } = event.kind {
|
|
logs.lock().unwrap().push(format!("Event: {event:?}"));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
// ANCHOR_END: db_impl
|