salsa/tests/tracked_method_on_tracked_struct.rs

67 lines
1.5 KiB
Rust
Raw Normal View History

2024-07-18 11:48:38 +00:00
use salsa::Database;
#[derive(Debug, PartialEq, Eq, Hash)]
pub struct Item {}
#[salsa::input]
pub struct Input {
name: String,
}
#[salsa::tracked]
impl Input {
#[salsa::tracked]
pub fn source_tree(self, db: &dyn Database) -> SourceTree<'_> {
SourceTree::new(db, self.name(db).clone())
}
}
#[salsa::tracked]
pub struct SourceTree<'db> {
name: String,
}
#[salsa::tracked]
impl<'db1> SourceTree<'db1> {
#[salsa::tracked(return_ref)]
pub fn inherent_item_name(self, db: &'db1 dyn Database) -> String {
self.name(db)
}
}
trait ItemName<'db1> {
fn trait_item_name(self, db: &'db1 dyn Database) -> &'db1 String;
}
#[salsa::tracked]
impl<'db1> ItemName<'db1> for SourceTree<'db1> {
#[salsa::tracked(return_ref)]
fn trait_item_name(self, db: &'db1 dyn Database) -> String {
self.name(db)
}
}
#[test]
fn test_inherent() {
salsa::DatabaseImpl::new().attach(|db| {
2024-07-18 11:48:38 +00:00
let input = Input::new(db, "foo".to_string());
let source_tree = input.source_tree(db);
expect_test::expect![[r#"
"foo"
"#]]
.assert_debug_eq(source_tree.inherent_item_name(db));
})
}
#[test]
fn test_trait() {
salsa::DatabaseImpl::new().attach(|db| {
2024-07-18 11:48:38 +00:00
let input = Input::new(db, "foo".to_string());
let source_tree = input.source_tree(db);
expect_test::expect![[r#"
"foo"
"#]]
.assert_debug_eq(source_tree.trait_item_name(db));
})
}