Struct cairo_lang_semantic::db::PrivTraitTypeDataQuery
source · pub struct PrivTraitTypeDataQuery;Implementations§
source§impl PrivTraitTypeDataQuery
impl PrivTraitTypeDataQuery
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 PrivTraitTypeDataQuery
impl PrivTraitTypeDataQuery
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 PrivTraitTypeDataQuery
impl Debug for PrivTraitTypeDataQuery
source§impl Default for PrivTraitTypeDataQuery
impl Default for PrivTraitTypeDataQuery
source§fn default() -> PrivTraitTypeDataQuery
fn default() -> PrivTraitTypeDataQuery
source§impl Query for PrivTraitTypeDataQuery
impl Query for PrivTraitTypeDataQuery
§type Key = TraitTypeId
type Key = TraitTypeId
§type Value = Result<TraitItemTypeData, DiagnosticAdded>
type Value = Result<TraitItemTypeData, DiagnosticAdded>
§type Storage = DerivedStorage<PrivTraitTypeDataQuery, AlwaysMemoizeValue>
type Storage = DerivedStorage<PrivTraitTypeDataQuery, AlwaysMemoizeValue>
source§const QUERY_INDEX: u16 = 98u16
const QUERY_INDEX: u16 = 98u16
source§const QUERY_NAME: &'static str = "priv_trait_type_data"
const QUERY_NAME: &'static str = "priv_trait_type_data"
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 PrivTraitTypeDataQuery
impl<'d> QueryDb<'d> for PrivTraitTypeDataQuery
§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 PrivTraitTypeDataQuery
impl RefUnwindSafe for PrivTraitTypeDataQuery
impl Send for PrivTraitTypeDataQuery
impl Sync for PrivTraitTypeDataQuery
impl Unpin for PrivTraitTypeDataQuery
impl UnwindSafe for PrivTraitTypeDataQuery
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