Struct ra_ap_base_db::FileTextQuery
source · [−]pub struct FileTextQuery;Implementations
sourceimpl FileTextQuery
impl FileTextQuery
sourcepub fn in_db(self, db: &dyn SourceDatabaseExt) -> QueryTable<'_, Self>
pub fn in_db(self, db: &dyn SourceDatabaseExt) -> QueryTable<'_, Self>
Get access to extra methods pertaining to this query. You can also use it to invoke this query, though it’s more common to use the trait method on the database itself.
sourceimpl FileTextQuery
impl FileTextQuery
sourcepub fn in_db_mut(self, db: &mut dyn SourceDatabaseExt) -> QueryTableMut<'_, Self>
pub fn in_db_mut(self, db: &mut dyn SourceDatabaseExt) -> 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. 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 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
sourceimpl Debug for FileTextQuery
impl Debug for FileTextQuery
sourceimpl Default for FileTextQuery
impl Default for FileTextQuery
sourcefn default() -> FileTextQuery
fn default() -> FileTextQuery
Returns the “default value” for a type. Read more
sourceimpl Query for FileTextQuery
impl Query for FileTextQuery
type Key = FileId
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. Read more
type Storage = InputStorage<FileTextQuery>
type Storage = InputStorage<FileTextQuery>
Internal struct storing the values for the query.
sourceconst QUERY_INDEX: u16 = 0u16
const QUERY_INDEX: u16 = 0u16
A unique index identifying this query within the group.
sourceconst QUERY_NAME: &'static str = _
const QUERY_NAME: &'static str = _
Name of the query method (e.g., foo)
sourcefn 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>
Extact storage for this query from the storage for its group.
sourceimpl<'d> QueryDb<'d> for FileTextQuery
impl<'d> QueryDb<'d> for FileTextQuery
type DynDb = dyn SourceDatabaseExt + 'd
type DynDb = dyn SourceDatabaseExt + 'd
Dyn version of the associated trait for this query group.
type Group = SourceDatabaseExtStorage
type Group = SourceDatabaseExtStorage
Associate query group struct.
type GroupStorage = SourceDatabaseExtGroupStorage__
type GroupStorage = SourceDatabaseExtGroupStorage__
Generated struct that contains storage for all queries in a group.
Auto Trait Implementations
impl RefUnwindSafe for FileTextQuery
impl Send for FileTextQuery
impl Sync for FileTextQuery
impl Unpin for FileTextQuery
impl UnwindSafe for FileTextQuery
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more