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

101 lines
3.0 KiB
Rust
Raw Normal View History

2020-03-18 10:32:58 +01:00
use crate::ty::{self, TyCtxt};
use rustc_data_structures::profiling::SelfProfilerRef;
2020-11-14 16:48:54 +01:00
use rustc_query_system::ich::StableHashingContext;
use rustc_session::Session;
2020-03-18 10:32:58 +01:00
2021-01-19 19:07:06 +01:00
#[macro_use]
2020-03-18 10:32:58 +01:00
mod dep_node;
pub use rustc_query_system::dep_graph::{
2021-03-02 22:38:49 +01:00
debug::DepNodeFilter, hash_result, DepContext, DepNodeColor, DepNodeIndex,
SerializedDepNodeIndex, WorkProduct, WorkProductId,
2020-03-18 10:32:58 +01:00
};
pub use dep_node::{label_strs, DepKind, DepNode, DepNodeExt};
pub(crate) use dep_node::{make_compile_codegen_unit, make_compile_mono_item};
2020-03-18 10:32:58 +01:00
pub type DepGraph = rustc_query_system::dep_graph::DepGraph<DepKind>;
2020-03-18 10:32:58 +01:00
pub type TaskDeps = rustc_query_system::dep_graph::TaskDeps<DepKind>;
pub type TaskDepsRef<'a> = rustc_query_system::dep_graph::TaskDepsRef<'a, DepKind>;
2020-03-18 10:32:58 +01:00
pub type DepGraphQuery = rustc_query_system::dep_graph::DepGraphQuery<DepKind>;
pub type SerializedDepGraph = rustc_query_system::dep_graph::SerializedDepGraph<DepKind>;
2021-03-02 22:38:49 +01:00
pub type EdgeFilter = rustc_query_system::dep_graph::debug::EdgeFilter<DepKind>;
pub type DepKindStruct<'tcx> = rustc_query_system::dep_graph::DepKindStruct<TyCtxt<'tcx>>;
2020-03-18 10:32:58 +01:00
impl rustc_query_system::dep_graph::DepKind for DepKind {
2020-03-18 21:02:02 +01:00
const NULL: Self = DepKind::Null;
const RED: Self = DepKind::Red;
2020-03-18 21:02:02 +01:00
2020-03-18 10:32:58 +01:00
fn debug_node(node: &DepNode, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
2021-10-16 21:24:10 +02:00
write!(f, "{:?}(", node.kind)?;
2020-03-18 10:32:58 +01:00
ty::tls::with_opt(|opt_tcx| {
if let Some(tcx) = opt_tcx {
2020-03-21 09:28:37 +01:00
if let Some(def_id) = node.extract_def_id(tcx) {
2020-03-18 10:32:58 +01:00
write!(f, "{}", tcx.def_path_debug_str(def_id))?;
} else if let Some(ref s) = tcx.dep_graph.dep_node_debug_str(*node) {
write!(f, "{}", s)?;
} else {
write!(f, "{}", node.hash)?;
}
} else {
write!(f, "{}", node.hash)?;
}
Ok(())
})?;
write!(f, ")")
}
fn with_deps<OP, R>(task_deps: TaskDepsRef<'_>, op: OP) -> R
2020-03-18 10:32:58 +01:00
where
OP: FnOnce() -> R,
{
ty::tls::with_context(|icx| {
let icx = ty::tls::ImplicitCtxt { task_deps, ..icx.clone() };
ty::tls::enter_context(&icx, |_| op())
})
}
fn read_deps<OP>(op: OP)
2020-03-18 10:32:58 +01:00
where
OP: for<'a> FnOnce(TaskDepsRef<'a>),
2020-03-18 10:32:58 +01:00
{
ty::tls::with_context_opt(|icx| {
2022-02-15 05:58:25 +01:00
let Some(icx) = icx else { return };
2020-03-18 10:32:58 +01:00
op(icx.task_deps)
})
}
}
impl<'tcx> DepContext for TyCtxt<'tcx> {
type DepKind = DepKind;
#[inline]
fn with_stable_hashing_context<R>(&self, f: impl FnOnce(StableHashingContext<'_>) -> R) -> R {
TyCtxt::with_stable_hashing_context(*self, f)
2020-03-18 10:32:58 +01:00
}
#[inline]
fn dep_graph(&self) -> &DepGraph {
&self.dep_graph
}
#[inline(always)]
2020-03-18 10:32:58 +01:00
fn profiler(&self) -> &SelfProfilerRef {
&self.prof
}
#[inline(always)]
fn sess(&self) -> &Session {
self.sess
}
2021-10-16 20:10:23 +02:00
#[inline]
fn dep_kind_info(&self, dep_kind: DepKind) -> &DepKindStruct<'tcx> {
&self.query_kinds[dep_kind as usize]
2021-10-16 20:24:08 +02:00
}
2020-03-18 10:32:58 +01:00
}