hir::db

Struct ConstEvalDiscriminantQuery

pub struct ConstEvalDiscriminantQuery;

Implementations§

§

impl ConstEvalDiscriminantQuery

pub fn in_db( self, db: &dyn HirDatabase, ) -> QueryTable<'_, ConstEvalDiscriminantQuery>

Get access to extra methods pertaining to this query. You can also use it to invoke this query.

§

impl ConstEvalDiscriminantQuery

pub fn in_db_mut( self, db: &mut dyn HirDatabase, ) -> QueryTableMut<'_, ConstEvalDiscriminantQuery>

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 Debug for ConstEvalDiscriminantQuery

§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
§

impl Default for ConstEvalDiscriminantQuery

§

fn default() -> ConstEvalDiscriminantQuery

Returns the “default value” for a type. Read more
§

impl Query for ConstEvalDiscriminantQuery

§

const QUERY_INDEX: u16 = 8u16

A unique index identifying this query within the group.
§

const QUERY_NAME: &'static str = "const_eval_discriminant"

Name of the query method (e.g., foo)
§

type Key = EnumVariantId

Type that you give as a parameter – for queries with zero or more than one input, this will be a tuple.
§

type Value = Result<i128, ConstEvalError>

What value does the query return?
§

type Storage = DerivedStorage<ConstEvalDiscriminantQuery>

Internal struct storing the values for the query.
§

fn query_storage<'a>( group_storage: &'a <ConstEvalDiscriminantQuery as QueryDb<'_>>::GroupStorage, ) -> &'a Arc<<ConstEvalDiscriminantQuery as Query>::Storage>

Extract storage for this query from the storage for its group.
§

fn query_storage_mut<'a>( group_storage: &'a <ConstEvalDiscriminantQuery as QueryDb<'_>>::GroupStorage, ) -> &'a Arc<<ConstEvalDiscriminantQuery as Query>::Storage>

Extract storage for this query from the storage for its group.
§

impl<'d> QueryDb<'d> for ConstEvalDiscriminantQuery

§

type DynDb = dyn HirDatabase + 'd

Dyn version of the associated trait for this query group.
§

type Group = HirDatabaseStorage

Associate query group struct.
§

type GroupStorage = HirDatabaseGroupStorage__

Generated struct that contains storage for all queries in a group.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Cast for T

§

fn cast<U>(self, interner: <U as HasInterner>::Interner) -> U
where Self: CastTo<U>, U: HasInterner,

Cast a value to type U using CastTo.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

§

impl<T> IntoBox<dyn Any> for T
where T: Any,

§

fn into_box(self) -> Box<dyn Any>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn Any + Send> for T
where T: Any + Send,

§

fn into_box(self) -> Box<dyn Any + Send>

Convert self into the appropriate boxed form.
§

impl<T> IntoBox<dyn Any + Sync + Send> for T
where T: Any + Send + Sync,

§

fn into_box(self) -> Box<dyn Any + Sync + Send>

Convert self into the appropriate boxed form.
source§

impl<T> IntoEither for T

source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<'a, T> Captures<'a> for T
where T: ?Sized,