From 891a866653adabe7443901c6806a834a6dc1e6b3 Mon Sep 17 00:00:00 2001 From: Niko Matsakis Date: Sun, 31 Oct 2021 09:47:15 -0400 Subject: [PATCH] refactor `Memo` to just be parameterized over `V` --- src/derived/slot.rs | 28 +++++++++++++--------------- 1 file changed, 13 insertions(+), 15 deletions(-) diff --git a/src/derived/slot.rs b/src/derived/slot.rs index d14ee135..31e1600f 100644 --- a/src/derived/slot.rs +++ b/src/derived/slot.rs @@ -49,15 +49,12 @@ where }, /// We have computed the query already, and here is the result. - Memoized(Memo), + Memoized(Memo), } -struct Memo -where - Q: QueryFunction, -{ +struct Memo { /// The result of the query, if we decide to memoize it. - value: Option, + value: Option, /// Revision information revisions: MemoRevisions, @@ -220,7 +217,9 @@ where // first things first, let's walk over each of our previous // inputs and check whether they are out of date. if let Some(memo) = &mut panic_guard.memo { - if let Some(value) = memo.validate_memoized_value(db, revision_now, &active_query) { + if let Some(value) = + memo.validate_memoized_value(db.ops_database(), revision_now, &active_query) + { info!("{:?}: validated old memoized value", self,); db.salsa_event(Event { @@ -649,7 +648,7 @@ where { database_key_index: DatabaseKeyIndex, slot: &'me Slot, - memo: Option>, + memo: Option>, runtime: &'me Runtime, } @@ -661,7 +660,7 @@ where fn new( database_key_index: DatabaseKeyIndex, slot: &'me Slot, - memo: Option>, + memo: Option>, runtime: &'me Runtime, ) -> Self { Self { @@ -737,9 +736,9 @@ where } } -impl Memo +impl Memo where - Q: QueryFunction, + V: Clone, { /// Determines whether the memo is still valid in the current /// revision. If needed, this will walk each dependency and @@ -750,20 +749,19 @@ where /// takes the `active_query` argument as evidence. fn validate_memoized_value( &mut self, - db: &>::DynDb, + db: &dyn Database, revision_now: Revision, active_query: &ActiveQueryGuard<'_>, - ) -> Option> { + ) -> Option> { // If we don't have a memoized value, nothing to validate. let value = match &self.value { None => return None, Some(v) => v, }; - let dyn_db = db.ops_database(); if self .revisions - .validate_memoized_value(dyn_db, revision_now, active_query) + .validate_memoized_value(db, revision_now, active_query) { Some(StampedValue { durability: self.revisions.durability,