rust/compiler/rustc_query_system/src/query/config.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

80 lines
2.7 KiB
Rust
Raw Normal View History

2020-03-08 17:24:56 +01:00
//! Query configuration and description traits.
use crate::dep_graph::DepNode;
2019-02-05 11:20:45 -06:00
use crate::dep_graph::SerializedDepNodeIndex;
use crate::ich::StableHashingContext;
2020-03-19 14:13:31 +01:00
use crate::query::caches::QueryCache;
use crate::query::{QueryContext, QueryState};
2017-09-18 05:40:13 -04:00
use rustc_data_structures::fingerprint::Fingerprint;
use rustc_errors::{DiagnosticBuilder, ErrorGuaranteed};
use std::fmt::Debug;
2019-06-12 14:39:12 +02:00
use std::hash::Hash;
2017-09-18 05:40:13 -04:00
pub trait QueryConfig {
const NAME: &'static str;
type Key: Eq + Hash + Clone + Debug;
type Value;
type Stored: Clone;
2018-06-13 16:44:43 +03:00
}
pub struct QueryVTable<CTX: QueryContext, K, V> {
2020-03-06 22:56:05 +01:00
pub anon: bool,
pub dep_kind: CTX::DepKind,
2020-03-06 22:15:46 +01:00
pub eval_always: bool,
2022-08-24 09:42:12 +08:00
pub depth_limit: bool,
2021-10-17 17:37:20 +02:00
pub cache_on_disk: bool,
2020-03-06 22:15:46 +01:00
2021-07-11 20:08:17 +02:00
pub compute: fn(CTX::DepContext, K) -> V,
2021-10-16 22:31:48 +02:00
pub hash_result: Option<fn(&mut StableHashingContext<'_>, &V) -> Fingerprint>,
pub handle_cycle_error: fn(CTX, DiagnosticBuilder<'_, ErrorGuaranteed>) -> V,
2021-10-17 17:37:20 +02:00
pub try_load_from_disk: Option<fn(CTX, SerializedDepNodeIndex) -> Option<V>>,
}
impl<CTX: QueryContext, K, V> QueryVTable<CTX, K, V> {
2020-10-18 21:01:36 +02:00
pub(crate) fn to_dep_node(&self, tcx: CTX::DepContext, key: &K) -> DepNode<CTX::DepKind>
where
2020-10-18 21:01:36 +02:00
K: crate::dep_graph::DepNodeParams<CTX::DepContext>,
{
DepNode::construct(tcx, self.dep_kind, key)
2020-03-28 13:12:20 +01:00
}
2021-07-11 20:08:17 +02:00
pub(crate) fn compute(&self, tcx: CTX::DepContext, key: K) -> V {
(self.compute)(tcx, key)
}
pub(crate) fn try_load_from_disk(&self, tcx: CTX, index: SerializedDepNodeIndex) -> Option<V> {
2021-10-17 17:37:20 +02:00
self.try_load_from_disk
.expect("QueryDescription::load_from_disk() called for an unsupported query.")(
tcx, index,
)
}
2020-03-06 22:15:46 +01:00
}
2021-10-17 17:37:20 +02:00
pub trait QueryDescription<CTX: QueryContext>: QueryConfig {
const TRY_LOAD_FROM_DISK: Option<fn(CTX, SerializedDepNodeIndex) -> Option<Self::Value>>;
type Cache: QueryCache<Key = Self::Key, Stored = Self::Stored, Value = Self::Value>;
2021-10-17 17:37:20 +02:00
fn describe(tcx: CTX, key: Self::Key) -> String;
2018-04-27 12:08:54 +02:00
// Don't use this method to access query results, instead use the methods on TyCtxt
fn query_state<'a>(tcx: CTX) -> &'a QueryState<Self::Key>
2020-12-26 16:36:55 +01:00
where
CTX: 'a;
// Don't use this method to access query results, instead use the methods on TyCtxt
fn query_cache<'a>(tcx: CTX) -> &'a Self::Cache
where
CTX: 'a;
2018-04-27 12:08:54 +02:00
// Don't use this method to compute query results, instead use the methods on TyCtxt
fn make_vtable(tcx: CTX, key: &Self::Key) -> QueryVTable<CTX, Self::Key, Self::Value>;
fn cache_on_disk(tcx: CTX::DepContext, key: &Self::Key) -> bool;
// Don't use this method to compute query results, instead use the methods on TyCtxt
fn execute_query(tcx: CTX::DepContext, k: Self::Key) -> Self::Stored;
2020-03-06 22:15:46 +01:00
}