Struct cairo_lang_semantic::db::ImplImplByIdQuery
source · pub struct ImplImplByIdQuery;
Implementations§
source§impl ImplImplByIdQuery
impl ImplImplByIdQuery
sourcepub fn in_db(self, db: &dyn SemanticGroup) -> QueryTable<'_, Self>
pub fn in_db(self, db: &dyn SemanticGroup) -> QueryTable<'_, Self>
Get access to extra methods pertaining to this query. For
example, you can use this to run the GC (sweep
) across a
single input. You can also use it to invoke this query, though
it’s more common to use the trait method on the database
itself.
source§impl ImplImplByIdQuery
impl ImplImplByIdQuery
sourcepub fn in_db_mut(self, db: &mut dyn SemanticGroup) -> QueryTableMut<'_, Self>
pub fn in_db_mut(self, db: &mut dyn SemanticGroup) -> QueryTableMut<'_, Self>
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. In the threads operating on
snapshots, you can use the is_current_revision_canceled
method to check for this flag and bring those operations to a
close, thus allowing the set
to succeed. Ignoring this flag
may lead to “starvation”, meaning that the thread attempting
to set
has to wait a long, long time. =)
Trait Implementations§
source§impl Debug for ImplImplByIdQuery
impl Debug for ImplImplByIdQuery
source§impl Default for ImplImplByIdQuery
impl Default for ImplImplByIdQuery
source§fn default() -> ImplImplByIdQuery
fn default() -> ImplImplByIdQuery
source§impl Query for ImplImplByIdQuery
impl Query for ImplImplByIdQuery
§type Key = ImplImplDefId
type Key = ImplImplDefId
§type Value = Result<Option<ItemImplAlias>, DiagnosticAdded>
type Value = Result<Option<ItemImplAlias>, DiagnosticAdded>
§type Storage = DerivedStorage<ImplImplByIdQuery, AlwaysMemoizeValue>
type Storage = DerivedStorage<ImplImplByIdQuery, AlwaysMemoizeValue>
source§const QUERY_INDEX: u16 = 153u16
const QUERY_INDEX: u16 = 153u16
source§const QUERY_NAME: &'static str = "impl_impl_by_id"
const QUERY_NAME: &'static str = "impl_impl_by_id"
foo
)source§fn query_storage<'a>(
group_storage: &'a <Self as QueryDb<'_>>::GroupStorage,
) -> &'a Arc<Self::Storage>
fn query_storage<'a>( group_storage: &'a <Self as QueryDb<'_>>::GroupStorage, ) -> &'a Arc<Self::Storage>
source§impl<'d> QueryDb<'d> for ImplImplByIdQuery
impl<'d> QueryDb<'d> for ImplImplByIdQuery
§type DynDb = dyn SemanticGroup + 'd
type DynDb = dyn SemanticGroup + 'd
§type Group = SemanticDatabase
type Group = SemanticDatabase
§type GroupStorage = SemanticGroupGroupStorage__
type GroupStorage = SemanticGroupGroupStorage__
Auto Trait Implementations§
impl Freeze for ImplImplByIdQuery
impl RefUnwindSafe for ImplImplByIdQuery
impl Send for ImplImplByIdQuery
impl Sync for ImplImplByIdQuery
impl Unpin for ImplImplByIdQuery
impl UnwindSafe for ImplImplByIdQuery
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
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