mirror of
https://github.com/salsa-rs/salsa.git
synced 2025-01-23 05:07:27 +00:00
73 lines
1.3 KiB
Rust
73 lines
1.3 KiB
Rust
|
mod common;
|
||
|
|
||
|
use common::{HasLogger, Logger};
|
||
|
use expect_test::expect;
|
||
|
use salsa::Setter as _;
|
||
|
|
||
|
#[salsa::db]
|
||
|
trait Db: salsa::Database + HasLogger {}
|
||
|
|
||
|
#[salsa::input]
|
||
|
struct Input {
|
||
|
number: i16,
|
||
|
}
|
||
|
|
||
|
#[salsa::tracked(no_eq)]
|
||
|
fn abs_float(db: &dyn Db, input: Input) -> f32 {
|
||
|
let number = input.number(db);
|
||
|
|
||
|
db.push_log(format!("abs_float({number})"));
|
||
|
number.abs() as f32
|
||
|
}
|
||
|
|
||
|
#[salsa::tracked]
|
||
|
fn derived(db: &dyn Db, input: Input) -> u32 {
|
||
|
let x = abs_float(db, input);
|
||
|
db.push_log("derived".to_string());
|
||
|
|
||
|
x as u32
|
||
|
}
|
||
|
|
||
|
#[salsa::db]
|
||
|
#[derive(Default)]
|
||
|
struct Database {
|
||
|
storage: salsa::Storage<Self>,
|
||
|
logger: Logger,
|
||
|
}
|
||
|
|
||
|
impl HasLogger for Database {
|
||
|
fn logger(&self) -> &Logger {
|
||
|
&self.logger
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#[salsa::db]
|
||
|
impl salsa::Database for Database {}
|
||
|
|
||
|
#[salsa::db]
|
||
|
impl Db for Database {}
|
||
|
|
||
|
#[test]
|
||
|
fn invoke() {
|
||
|
let mut db = Database::default();
|
||
|
|
||
|
let input = Input::new(&db, 5);
|
||
|
let x = derived(&db, input);
|
||
|
|
||
|
assert_eq!(x, 5);
|
||
|
|
||
|
input.set_number(&mut db).to(-5);
|
||
|
|
||
|
// Derived should re-execute even the result of `abs_float` is the same.
|
||
|
let x = derived(&db, input);
|
||
|
assert_eq!(x, 5);
|
||
|
|
||
|
db.assert_logs(expect![[r#"
|
||
|
[
|
||
|
"abs_float(5)",
|
||
|
"derived",
|
||
|
"abs_float(-5)",
|
||
|
"derived",
|
||
|
]"#]]);
|
||
|
}
|