Struct MonomorphizedMirBodyForClosureQuery
pub struct MonomorphizedMirBodyForClosureQuery;
Implementations§
§impl MonomorphizedMirBodyForClosureQuery
impl MonomorphizedMirBodyForClosureQuery
pub fn in_db(
self,
db: &dyn HirDatabase,
) -> QueryTable<'_, MonomorphizedMirBodyForClosureQuery>
pub fn in_db( self, db: &dyn HirDatabase, ) -> QueryTable<'_, MonomorphizedMirBodyForClosureQuery>
Get access to extra methods pertaining to this query. You can also use it to invoke this query.
§impl MonomorphizedMirBodyForClosureQuery
impl MonomorphizedMirBodyForClosureQuery
pub fn in_db_mut(
self,
db: &mut dyn HirDatabase,
) -> QueryTableMut<'_, MonomorphizedMirBodyForClosureQuery>
pub fn in_db_mut( self, db: &mut dyn HirDatabase, ) -> QueryTableMut<'_, MonomorphizedMirBodyForClosureQuery>
Like in_db
, but gives access to methods for setting the
value of an input. Not applicable to derived queries.
§Threads, cancellation, and blocking
Mutating the value of a query cannot be done while there are
still other queries executing. If you are using your database
within a single thread, this is not a problem: you only have
&self
access to the database, but this method requires &mut self
.
However, if you have used snapshot
to create other threads,
then attempts to set
will block the current thread until
those snapshots are dropped (usually when those threads
complete). This also implies that if you create a snapshot but
do not send it to another thread, then invoking set
will
deadlock.
Before blocking, the thread that is attempting to set
will
also set a cancellation flag. This will cause any query
invocations in other threads to unwind with a Cancelled
sentinel value and eventually let the set
succeed once all
threads have unwound past the ra_salsa invocation.
If your query implementations are performing expensive
operations without invoking another query, you can also use
the Runtime::unwind_if_cancelled
method to check for an
ongoing cancellation and bring those operations to a close,
thus allowing the set
to succeed. Otherwise, long-running
computations may lead to “starvation”, meaning that the
thread attempting to set
has to wait a long, long time. =)
Trait Implementations§
§impl Default for MonomorphizedMirBodyForClosureQuery
impl Default for MonomorphizedMirBodyForClosureQuery
§fn default() -> MonomorphizedMirBodyForClosureQuery
fn default() -> MonomorphizedMirBodyForClosureQuery
§impl Query for MonomorphizedMirBodyForClosureQuery
impl Query for MonomorphizedMirBodyForClosureQuery
§const QUERY_INDEX: u16 = 4u16
const QUERY_INDEX: u16 = 4u16
§const QUERY_NAME: &'static str = "monomorphized_mir_body_for_closure"
const QUERY_NAME: &'static str = "monomorphized_mir_body_for_closure"
foo
)§type Key = (ClosureId<Interner>, Substitution<Interner>, Arc<TraitEnvironment>)
type Key = (ClosureId<Interner>, Substitution<Interner>, Arc<TraitEnvironment>)
§type Value = Result<Arc<MirBody>, MirLowerError>
type Value = Result<Arc<MirBody>, MirLowerError>
§type Storage = DerivedStorage<MonomorphizedMirBodyForClosureQuery>
type Storage = DerivedStorage<MonomorphizedMirBodyForClosureQuery>
§fn query_storage<'a>(
group_storage: &'a <MonomorphizedMirBodyForClosureQuery as QueryDb<'_>>::GroupStorage,
) -> &'a Arc<<MonomorphizedMirBodyForClosureQuery as Query>::Storage>
fn query_storage<'a>( group_storage: &'a <MonomorphizedMirBodyForClosureQuery as QueryDb<'_>>::GroupStorage, ) -> &'a Arc<<MonomorphizedMirBodyForClosureQuery as Query>::Storage>
§fn query_storage_mut<'a>(
group_storage: &'a <MonomorphizedMirBodyForClosureQuery as QueryDb<'_>>::GroupStorage,
) -> &'a Arc<<MonomorphizedMirBodyForClosureQuery as Query>::Storage>
fn query_storage_mut<'a>( group_storage: &'a <MonomorphizedMirBodyForClosureQuery as QueryDb<'_>>::GroupStorage, ) -> &'a Arc<<MonomorphizedMirBodyForClosureQuery as Query>::Storage>
§impl<'d> QueryDb<'d> for MonomorphizedMirBodyForClosureQuery
impl<'d> QueryDb<'d> for MonomorphizedMirBodyForClosureQuery
§type DynDb = dyn HirDatabase + 'd
type DynDb = dyn HirDatabase + 'd
§type Group = HirDatabaseStorage
type Group = HirDatabaseStorage
§type GroupStorage = HirDatabaseGroupStorage__
type GroupStorage = HirDatabaseGroupStorage__
Auto Trait Implementations§
impl Freeze for MonomorphizedMirBodyForClosureQuery
impl RefUnwindSafe for MonomorphizedMirBodyForClosureQuery
impl Send for MonomorphizedMirBodyForClosureQuery
impl Sync for MonomorphizedMirBodyForClosureQuery
impl Unpin for MonomorphizedMirBodyForClosureQuery
impl UnwindSafe for MonomorphizedMirBodyForClosureQuery
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Cast for T
impl<T> Cast for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more