pub struct FileSyntaxDiagnosticsQuery;

Implementations§

source§

impl FileSyntaxDiagnosticsQuery

source

pub fn in_db(self, db: &dyn ParserGroup) -> 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 FileSyntaxDiagnosticsQuery

source

pub fn in_db_mut(self, db: &mut dyn ParserGroup) -> 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 FileSyntaxDiagnosticsQuery

source§

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

Formats the value using the given formatter. Read more
source§

impl Default for FileSyntaxDiagnosticsQuery

source§

fn default() -> FileSyntaxDiagnosticsQuery

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

impl Query for FileSyntaxDiagnosticsQuery

§

type Key = FileId

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

type Value = Diagnostics<ParserDiagnostic>

What value does the query return?
§

type Storage = DerivedStorage<FileSyntaxDiagnosticsQuery, AlwaysMemoizeValue>

Internal struct storing the values for the query.
source§

const QUERY_INDEX: u16 = 2u16

A unique index identifying this query within the group.
source§

const QUERY_NAME: &'static str = _

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

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

Extact storage for this query from the storage for its group.
source§

impl<'d> QueryDb<'d> for FileSyntaxDiagnosticsQuery

§

type DynDb = dyn ParserGroup + 'd

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

type Group = ParserDatabase

Associate query group struct.
§

type GroupStorage = ParserGroupGroupStorage__

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

impl QueryFunction for FileSyntaxDiagnosticsQuery

source§

fn execute( db: &<Self as QueryDb<'_>>::DynDb, key0: <Self as Query>::Key ) -> <Self as Query>::Value

source§

fn recover( db: &Self::DynDb, cycle: &[DatabaseKeyIndex], key: &Self::Key ) -> Option<Self::Value>

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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.

source§

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

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

impl<T> Upcast<T> for Twhere T: ?Sized,

source§

fn upcast(&self) -> &T