Merge pull request #449 from DropDemBits/assert-on-tracked-struct-outside-of-tracked-fn

Improve assert message when creating a tracked struct outside of a tracked function
This commit is contained in:
Niko Matsakis 2023-10-28 06:58:14 -04:00 committed by GitHub
commit 6ac3724e0a
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 35 additions and 1 deletions

View file

@ -291,7 +291,10 @@ impl LocalState {
#[track_caller]
pub(crate) fn disambiguate(&self, data_hash: u64) -> (DatabaseKeyIndex, Disambiguator) {
assert!(self.query_in_progress());
assert!(
self.query_in_progress(),
"cannot create a tracked struct disambiguator outside of a tracked function"
);
self.with_query_stack(|stack| {
let top_query = stack.last_mut().unwrap();
let disambiguator = top_query.disambiguate(data_hash);

View file

@ -0,0 +1,31 @@
//! Test that creating a tracked struct outside of a
//! tracked function panics with an assert message.
#[salsa::jar(db = Db)]
struct Jar(MyTracked);
trait Db: salsa::DbWithJar<Jar> {}
#[salsa::tracked(jar = Jar)]
struct MyTracked {
field: u32,
}
#[salsa::db(Jar)]
#[derive(Default)]
struct Database {
storage: salsa::Storage<Self>,
}
impl salsa::Database for Database {}
impl Db for Database {}
#[test]
#[should_panic(
expected = "cannot create a tracked struct disambiguator outside of a tracked function"
)]
fn execute() {
let db = Database::default();
MyTracked::new(&db, 0);
}