Struct rustc_middle::ty::query::TyCtxtAt
source · Fields§
§tcx: TyCtxt<'tcx>
§span: Span
Implementations§
source§impl<'tcx> TyCtxtAt<'tcx>
impl<'tcx> TyCtxtAt<'tcx>
sourcepub fn eval_static_initializer(
self,
def_id: DefId
) -> Result<ConstAllocation<'tcx>, ErrorHandled>
pub fn eval_static_initializer(
self,
def_id: DefId
) -> Result<ConstAllocation<'tcx>, ErrorHandled>
Evaluate a static’s initializer, returning the allocation of the initializer’s memory.
The span is entirely ignored here, but still helpful for better query cycle errors.
sourcefn eval_to_allocation(
self,
gid: GlobalId<'tcx>,
param_env: ParamEnv<'tcx>
) -> Result<ConstAllocation<'tcx>, ErrorHandled>
fn eval_to_allocation(
self,
gid: GlobalId<'tcx>,
param_env: ParamEnv<'tcx>
) -> Result<ConstAllocation<'tcx>, ErrorHandled>
Evaluate anything constant-like, returning the allocation of the final memory.
The span is entirely ignored here, but still helpful for better query cycle errors.
source§impl<'tcx> TyCtxtAt<'tcx>
impl<'tcx> TyCtxtAt<'tcx>
sourcepub fn trigger_delay_span_bug(
self,
key: impl IntoQueryParam<DefId>
) -> trigger_delay_span_bug<'tcx>
pub fn trigger_delay_span_bug(
self,
key: impl IntoQueryParam<DefId>
) -> trigger_delay_span_bug<'tcx>
[query description - consider adding a doc-comment!] triggering a delay span bug
sourcepub fn resolutions(self, key: ()) -> resolutions<'tcx>
pub fn resolutions(self, key: ()) -> resolutions<'tcx>
[query description - consider adding a doc-comment!] getting the resolver outputs
sourcepub fn resolver_for_lowering(self, key: ()) -> resolver_for_lowering<'tcx>
pub fn resolver_for_lowering(self, key: ()) -> resolver_for_lowering<'tcx>
[query description - consider adding a doc-comment!] getting the resolver for lowering
sourcepub fn source_span(self, key: LocalDefId) -> source_span<'tcx>
pub fn source_span(self, key: LocalDefId) -> source_span<'tcx>
Return the span for a definition.
Contrary to def_span
below, this query returns the full absolute span of the definition.
This span is meant for dep-tracking rather than diagnostics. It should not be used outside
of rustc_middle::hir::source_map.
sourcepub fn hir_crate(self, key: ()) -> hir_crate<'tcx>
pub fn hir_crate(self, key: ()) -> hir_crate<'tcx>
Represents crate as a whole (as distinct from the top-level crate module).
If you call hir_crate
(e.g., indirectly by calling tcx.hir().krate()
),
we will have to assume that any change means that you need to be recompiled.
This is because the hir_crate
query gives you access to all other items.
To avoid this fate, do not call tcx.hir().krate()
; instead,
prefer wrappers like tcx.visit_all_items_in_krate()
.
sourcepub fn hir_crate_items(self, key: ()) -> hir_crate_items<'tcx>
pub fn hir_crate_items(self, key: ()) -> hir_crate_items<'tcx>
All items in the crate.
sourcepub fn hir_module_items(self, key: LocalDefId) -> hir_module_items<'tcx>
pub fn hir_module_items(self, key: LocalDefId) -> hir_module_items<'tcx>
The items in a module.
This can be conveniently accessed by tcx.hir().visit_item_likes_in_module
.
Avoid calling this query directly.
sourcepub fn hir_owner(self, key: OwnerId) -> hir_owner<'tcx>
pub fn hir_owner(self, key: OwnerId) -> hir_owner<'tcx>
Gives access to the HIR node for the HIR owner key
.
This can be conveniently accessed by methods on tcx.hir()
.
Avoid calling this query directly.
sourcepub fn local_def_id_to_hir_id(
self,
key: LocalDefId
) -> local_def_id_to_hir_id<'tcx>
pub fn local_def_id_to_hir_id(
self,
key: LocalDefId
) -> local_def_id_to_hir_id<'tcx>
Gives access to the HIR ID for the given LocalDefId
owner key
.
This can be conveniently accessed by methods on tcx.hir()
.
Avoid calling this query directly.
sourcepub fn hir_owner_parent(self, key: OwnerId) -> hir_owner_parent<'tcx>
pub fn hir_owner_parent(self, key: OwnerId) -> hir_owner_parent<'tcx>
Gives access to the HIR node’s parent for the HIR owner key
.
This can be conveniently accessed by methods on tcx.hir()
.
Avoid calling this query directly.
sourcepub fn hir_owner_nodes(self, key: OwnerId) -> hir_owner_nodes<'tcx>
pub fn hir_owner_nodes(self, key: OwnerId) -> hir_owner_nodes<'tcx>
Gives access to the HIR nodes and bodies inside the HIR owner key
.
This can be conveniently accessed by methods on tcx.hir()
.
Avoid calling this query directly.
sourcepub fn hir_attrs(self, key: OwnerId) -> hir_attrs<'tcx>
pub fn hir_attrs(self, key: OwnerId) -> hir_attrs<'tcx>
Gives access to the HIR attributes inside the HIR owner key
.
This can be conveniently accessed by methods on tcx.hir()
.
Avoid calling this query directly.
sourcepub fn opt_const_param_of(self, key: LocalDefId) -> opt_const_param_of<'tcx>
pub fn opt_const_param_of(self, key: LocalDefId) -> opt_const_param_of<'tcx>
Computes the DefId
of the corresponding const parameter in case the key
is a
const argument and returns None
otherwise.
let a = foo::<7>();
// ^ Calling `opt_const_param_of` for this argument,
fn foo<const N: usize>()
// ^ returns this `DefId`.
fn bar() {
// ^ While calling `opt_const_param_of` for other bodies returns `None`.
}
sourcepub fn const_param_default(
self,
key: impl IntoQueryParam<DefId>
) -> const_param_default<'tcx>
pub fn const_param_default(
self,
key: impl IntoQueryParam<DefId>
) -> const_param_default<'tcx>
Given the def_id of a const-generic parameter, computes the associated default const
parameter. e.g. fn example<const N: usize=3>
called on N
would return 3
.
sourcepub fn type_of(self, key: impl IntoQueryParam<DefId>) -> type_of<'tcx>
pub fn type_of(self, key: impl IntoQueryParam<DefId>) -> type_of<'tcx>
sourcepub fn collect_trait_impl_trait_tys(
self,
key: impl IntoQueryParam<DefId>
) -> collect_trait_impl_trait_tys<'tcx>
pub fn collect_trait_impl_trait_tys(
self,
key: impl IntoQueryParam<DefId>
) -> collect_trait_impl_trait_tys<'tcx>
[query description - consider adding a doc-comment!] comparing an impl and trait method signature, inferring any hidden impl Trait
types in the process
sourcepub fn analysis(self, key: ()) -> analysis<'tcx>
pub fn analysis(self, key: ()) -> analysis<'tcx>
[query description - consider adding a doc-comment!] running analysis passes on this crate
sourcepub fn check_expectations(self, key: Option<Symbol>) -> check_expectations<'tcx>
pub fn check_expectations(self, key: Option<Symbol>) -> check_expectations<'tcx>
This query checks the fulfillment of collected lint expectations. All lint emitting queries have to be done before this is executed to ensure that all expectations can be fulfilled.
This is an extra query to enable other drivers (like rustdoc) to
only execute a small subset of the analysis
query, while allowing
lints to be expected. In rustc, this query will be executed as part of
the analysis
query and doesn’t have to be called a second time.
Tools can additionally pass in a tool filter. That will restrict the
expectations to only trigger for lints starting with the listed tool
name. This is useful for cases were not all linting code from rustc
was called. With the default None
all registered lints will also
be checked for expectation fulfillment.
sourcepub fn generics_of(self, key: impl IntoQueryParam<DefId>) -> generics_of<'tcx>
pub fn generics_of(self, key: impl IntoQueryParam<DefId>) -> generics_of<'tcx>
Maps from the DefId
of an item (trait/struct/enum/fn) to its
associated generics.
sourcepub fn predicates_of(
self,
key: impl IntoQueryParam<DefId>
) -> predicates_of<'tcx>
pub fn predicates_of(
self,
key: impl IntoQueryParam<DefId>
) -> predicates_of<'tcx>
Maps from the DefId
of an item (trait/struct/enum/fn) to the
predicates (where-clauses) that must be proven true in order
to reference it. This is almost always the “predicates query”
that you want.
predicates_of
builds on predicates_defined_on
– in fact,
it is almost always the same as that query, except for the
case of traits. For traits, predicates_of
contains
an additional Self: Trait<...>
predicate that users don’t
actually write. This reflects the fact that to invoke the
trait (e.g., via Default::default
) you must supply types
that actually implement the trait. (However, this extra
predicate gets in the way of some checks, which are intended
to operate over only the actual where-clauses written by the
user.)
sourcepub fn explicit_item_bounds(
self,
key: impl IntoQueryParam<DefId>
) -> explicit_item_bounds<'tcx>
pub fn explicit_item_bounds(
self,
key: impl IntoQueryParam<DefId>
) -> explicit_item_bounds<'tcx>
Returns the list of bounds that can be used for
SelectionCandidate::ProjectionCandidate(_)
and
ProjectionTyCandidate::TraitDef
.
Specifically this is the bounds written on the trait’s type
definition, or those after the impl
keyword
type X: Bound + 'lt
// ^^^^^^^^^^^
impl Debug + Display
// ^^^^^^^^^^^^^^^
key
is the DefId
of the associated type or opaque type.
Bounds from the parent (e.g. with nested impl trait) are not included.
sourcepub fn item_bounds(self, key: impl IntoQueryParam<DefId>) -> item_bounds<'tcx>
pub fn item_bounds(self, key: impl IntoQueryParam<DefId>) -> item_bounds<'tcx>
Elaborated version of the predicates from explicit_item_bounds
.
For example:
trait MyTrait {
type MyAType: Eq + ?Sized;
}
explicit_item_bounds
returns [<Self as MyTrait>::MyAType: Eq]
,
and item_bounds
returns
[
<Self as Trait>::MyAType: Eq,
<Self as Trait>::MyAType: PartialEq<<Self as Trait>::MyAType>
]
Bounds from the parent (e.g. with nested impl trait) are not included.
sourcepub fn native_libraries(self, key: CrateNum) -> native_libraries<'tcx>
pub fn native_libraries(self, key: CrateNum) -> native_libraries<'tcx>
Look up all native libraries this crate depends on. These are assembled from the following places:
extern
blocks (depending on theirlink
attributes)- the
libs
(-l
) option
sourcepub fn shallow_lint_levels_on(self, key: OwnerId) -> shallow_lint_levels_on<'tcx>
pub fn shallow_lint_levels_on(self, key: OwnerId) -> shallow_lint_levels_on<'tcx>
[query description - consider adding a doc-comment!] looking up lint levels for tcx.def_path_str(key.to_def_id())
sourcepub fn lint_expectations(self, key: ()) -> lint_expectations<'tcx>
pub fn lint_expectations(self, key: ()) -> lint_expectations<'tcx>
[query description - consider adding a doc-comment!] computing #[expect]
ed lints in this crate
sourcepub fn parent_module_from_def_id(
self,
key: LocalDefId
) -> parent_module_from_def_id<'tcx>
pub fn parent_module_from_def_id(
self,
key: LocalDefId
) -> parent_module_from_def_id<'tcx>
[query description - consider adding a doc-comment!] getting the parent module of tcx.def_path_str(key.to_def_id())
sourcepub fn expn_that_defined(
self,
key: impl IntoQueryParam<DefId>
) -> expn_that_defined<'tcx>
pub fn expn_that_defined(
self,
key: impl IntoQueryParam<DefId>
) -> expn_that_defined<'tcx>
[query description - consider adding a doc-comment!] getting the expansion that defined tcx.def_path_str(key)
sourcepub fn is_panic_runtime(self, key: CrateNum) -> is_panic_runtime<'tcx>
pub fn is_panic_runtime(self, key: CrateNum) -> is_panic_runtime<'tcx>
[query description - consider adding a doc-comment!] checking if the crate is_panic_runtime
sourcepub fn representability(self, key: LocalDefId) -> representability<'tcx>
pub fn representability(self, key: LocalDefId) -> representability<'tcx>
Checks whether a type is representable or infinitely sized
sourcepub fn representability_adt_ty(
self,
key: Ty<'tcx>
) -> representability_adt_ty<'tcx>
pub fn representability_adt_ty(
self,
key: Ty<'tcx>
) -> representability_adt_ty<'tcx>
An implementation detail for the representability
query
sourcepub fn params_in_repr(
self,
key: impl IntoQueryParam<DefId>
) -> params_in_repr<'tcx>
pub fn params_in_repr(
self,
key: impl IntoQueryParam<DefId>
) -> params_in_repr<'tcx>
Set of param indexes for type params that are in the type’s representation
sourcepub fn thir_body(self, key: WithOptConstParam<LocalDefId>) -> thir_body<'tcx>
pub fn thir_body(self, key: WithOptConstParam<LocalDefId>) -> thir_body<'tcx>
Fetch the THIR for a given body. If typeck for that body failed, returns an empty Thir
.
sourcepub fn thir_tree(self, key: WithOptConstParam<LocalDefId>) -> thir_tree<'tcx>
pub fn thir_tree(self, key: WithOptConstParam<LocalDefId>) -> thir_tree<'tcx>
Create a THIR tree for debugging.
sourcepub fn mir_keys(self, key: ()) -> mir_keys<'tcx>
pub fn mir_keys(self, key: ()) -> mir_keys<'tcx>
Set of all the DefId
s in this crate that have MIR associated with
them. This includes all the body owners, but also things like struct
constructors.
sourcepub fn mir_const_qualif(
self,
key: impl IntoQueryParam<DefId>
) -> mir_const_qualif<'tcx>
pub fn mir_const_qualif(
self,
key: impl IntoQueryParam<DefId>
) -> mir_const_qualif<'tcx>
Maps DefId’s that have an associated mir::Body
to the result
of the MIR const-checking pass. This is the set of qualifs in
the final value of a const
.
sourcepub fn mir_const_qualif_const_arg(
self,
key: (LocalDefId, DefId)
) -> mir_const_qualif_const_arg<'tcx>
pub fn mir_const_qualif_const_arg(
self,
key: (LocalDefId, DefId)
) -> mir_const_qualif_const_arg<'tcx>
[query description - consider adding a doc-comment!] const checking the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn mir_built(self, key: WithOptConstParam<LocalDefId>) -> mir_built<'tcx>
pub fn mir_built(self, key: WithOptConstParam<LocalDefId>) -> mir_built<'tcx>
Fetch the MIR for a given DefId
right after it’s built - this includes
unreachable code.
sourcepub fn mir_const(self, key: WithOptConstParam<LocalDefId>) -> mir_const<'tcx>
pub fn mir_const(self, key: WithOptConstParam<LocalDefId>) -> mir_const<'tcx>
Fetch the MIR for a given DefId
up till the point where it is
ready for const qualification.
See the README for the mir
module for details.
sourcepub fn thir_abstract_const(
self,
key: impl IntoQueryParam<DefId>
) -> thir_abstract_const<'tcx>
pub fn thir_abstract_const(
self,
key: impl IntoQueryParam<DefId>
) -> thir_abstract_const<'tcx>
Try to build an abstract representation of the given constant.
sourcepub fn thir_abstract_const_of_const_arg(
self,
key: (LocalDefId, DefId)
) -> thir_abstract_const_of_const_arg<'tcx>
pub fn thir_abstract_const_of_const_arg(
self,
key: (LocalDefId, DefId)
) -> thir_abstract_const_of_const_arg<'tcx>
Try to build an abstract representation of the given constant.
sourcepub fn mir_drops_elaborated_and_const_checked(
self,
key: WithOptConstParam<LocalDefId>
) -> mir_drops_elaborated_and_const_checked<'tcx>
pub fn mir_drops_elaborated_and_const_checked(
self,
key: WithOptConstParam<LocalDefId>
) -> mir_drops_elaborated_and_const_checked<'tcx>
[query description - consider adding a doc-comment!] elaborating drops for tcx.def_path_str(key.did.to_def_id())
sourcepub fn mir_for_ctfe(self, key: impl IntoQueryParam<DefId>) -> mir_for_ctfe<'tcx>
pub fn mir_for_ctfe(self, key: impl IntoQueryParam<DefId>) -> mir_for_ctfe<'tcx>
[query description - consider adding a doc-comment!] caching mir of tcx.def_path_str(key)
for CTFE
sourcepub fn mir_for_ctfe_of_const_arg(
self,
key: (LocalDefId, DefId)
) -> mir_for_ctfe_of_const_arg<'tcx>
pub fn mir_for_ctfe_of_const_arg(
self,
key: (LocalDefId, DefId)
) -> mir_for_ctfe_of_const_arg<'tcx>
[query description - consider adding a doc-comment!] caching MIR for CTFE of the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn mir_promoted(
self,
key: WithOptConstParam<LocalDefId>
) -> mir_promoted<'tcx>
pub fn mir_promoted(
self,
key: WithOptConstParam<LocalDefId>
) -> mir_promoted<'tcx>
[query description - consider adding a doc-comment!] processing MIR for if key.const_param_did.is_some() { "the const argument " } else { "" }
tcx.def_path_str(key.did.to_def_id())
sourcepub fn symbols_for_closure_captures(
self,
key: (LocalDefId, LocalDefId)
) -> symbols_for_closure_captures<'tcx>
pub fn symbols_for_closure_captures(
self,
key: (LocalDefId, LocalDefId)
) -> symbols_for_closure_captures<'tcx>
[query description - consider adding a doc-comment!] finding symbols for captures of closure tcx.def_path_str(key.1.to_def_id())
in tcx.def_path_str(key.0.to_def_id())
sourcepub fn optimized_mir(
self,
key: impl IntoQueryParam<DefId>
) -> optimized_mir<'tcx>
pub fn optimized_mir(
self,
key: impl IntoQueryParam<DefId>
) -> optimized_mir<'tcx>
MIR after our optimization passes have run. This is MIR that is ready for codegen. This is also the only query that can fetch non-local MIR, at present.
sourcepub fn coverageinfo(self, key: InstanceDef<'tcx>) -> coverageinfo<'tcx>
pub fn coverageinfo(self, key: InstanceDef<'tcx>) -> coverageinfo<'tcx>
Returns coverage summary info for a function, after executing the InstrumentCoverage
MIR pass (assuming the -Cinstrument-coverage option is enabled).
sourcepub fn covered_code_regions(
self,
key: impl IntoQueryParam<DefId>
) -> covered_code_regions<'tcx>
pub fn covered_code_regions(
self,
key: impl IntoQueryParam<DefId>
) -> covered_code_regions<'tcx>
Returns the CodeRegions
for a function that has instrumented coverage, in case the
function was optimized out before codegen, and before being added to the Coverage Map.
sourcepub fn promoted_mir(self, key: impl IntoQueryParam<DefId>) -> promoted_mir<'tcx>
pub fn promoted_mir(self, key: impl IntoQueryParam<DefId>) -> promoted_mir<'tcx>
The DefId
is the DefId
of the containing MIR body. Promoteds do not have their own
DefId
. This function returns all promoteds in the specified body. The body references
promoteds by the DefId
and the mir::Promoted
index. This is necessary, because
after inlining a body may refer to promoteds from other bodies. In that case you still
need to use the DefId
of the original body.
sourcepub fn promoted_mir_of_const_arg(
self,
key: (LocalDefId, DefId)
) -> promoted_mir_of_const_arg<'tcx>
pub fn promoted_mir_of_const_arg(
self,
key: (LocalDefId, DefId)
) -> promoted_mir_of_const_arg<'tcx>
[query description - consider adding a doc-comment!] optimizing promoted MIR for the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn erase_regions_ty(self, key: Ty<'tcx>) -> erase_regions_ty<'tcx>
pub fn erase_regions_ty(self, key: Ty<'tcx>) -> erase_regions_ty<'tcx>
Erases regions from ty
to yield a new type.
Normally you would just use tcx.erase_regions(value)
,
however, which uses this query as a kind of cache.
sourcepub fn wasm_import_module_map(
self,
key: CrateNum
) -> wasm_import_module_map<'tcx>
pub fn wasm_import_module_map(
self,
key: CrateNum
) -> wasm_import_module_map<'tcx>
[query description - consider adding a doc-comment!] getting wasm import module map
sourcepub fn predicates_defined_on(
self,
key: impl IntoQueryParam<DefId>
) -> predicates_defined_on<'tcx>
pub fn predicates_defined_on(
self,
key: impl IntoQueryParam<DefId>
) -> predicates_defined_on<'tcx>
Maps from the DefId
of an item (trait/struct/enum/fn) to the
predicates (where-clauses) directly defined on it. This is
equal to the explicit_predicates_of
predicates plus the
inferred_outlives_of
predicates.
sourcepub fn trait_explicit_predicates_and_bounds(
self,
key: LocalDefId
) -> trait_explicit_predicates_and_bounds<'tcx>
pub fn trait_explicit_predicates_and_bounds(
self,
key: LocalDefId
) -> trait_explicit_predicates_and_bounds<'tcx>
Returns everything that looks like a predicate written explicitly by the user on a trait item.
Traits are unusual, because predicates on associated types are converted into bounds on that type for backwards compatibility:
trait X where Self::U: Copy { type U; }
becomes
trait X { type U: Copy; }
explicit_predicates_of
and explicit_item_bounds
will then take
the appropriate subsets of the predicates here.
sourcepub fn explicit_predicates_of(
self,
key: impl IntoQueryParam<DefId>
) -> explicit_predicates_of<'tcx>
pub fn explicit_predicates_of(
self,
key: impl IntoQueryParam<DefId>
) -> explicit_predicates_of<'tcx>
Returns the predicates written explicitly by the user.
sourcepub fn inferred_outlives_of(
self,
key: impl IntoQueryParam<DefId>
) -> inferred_outlives_of<'tcx>
pub fn inferred_outlives_of(
self,
key: impl IntoQueryParam<DefId>
) -> inferred_outlives_of<'tcx>
Returns the inferred outlives predicates (e.g., for struct Foo<'a, T> { x: &'a T }
, this would return T: 'a
).
sourcepub fn super_predicates_of(
self,
key: impl IntoQueryParam<DefId>
) -> super_predicates_of<'tcx>
pub fn super_predicates_of(
self,
key: impl IntoQueryParam<DefId>
) -> super_predicates_of<'tcx>
Maps from the DefId
of a trait to the list of
super-predicates. This is a subset of the full list of
predicates. We store these in a separate map because we must
evaluate them even during type conversion, often before the
full predicates are available (note that supertraits have
additional acyclicity requirements).
sourcepub fn super_predicates_that_define_assoc_type(
self,
key: (DefId, Option<Ident>)
) -> super_predicates_that_define_assoc_type<'tcx>
pub fn super_predicates_that_define_assoc_type(
self,
key: (DefId, Option<Ident>)
) -> super_predicates_that_define_assoc_type<'tcx>
The Option<Ident>
is the name of an associated type. If it is None
, then this query
returns the full set of predicates. If Some<Ident>
, then the query returns only the
subset of super-predicates that reference traits that define the given associated type.
This is used to avoid cycles in resolving types like T::Item
.
sourcepub fn type_param_predicates(
self,
key: (DefId, LocalDefId, Ident)
) -> type_param_predicates<'tcx>
pub fn type_param_predicates(
self,
key: (DefId, LocalDefId, Ident)
) -> type_param_predicates<'tcx>
To avoid cycles within the predicates of a single item we compute
per-type-parameter predicates for resolving T::AssocTy
.
sourcepub fn trait_def(self, key: impl IntoQueryParam<DefId>) -> trait_def<'tcx>
pub fn trait_def(self, key: impl IntoQueryParam<DefId>) -> trait_def<'tcx>
[query description - consider adding a doc-comment!] computing trait definition for tcx.def_path_str(key)
sourcepub fn adt_def(self, key: impl IntoQueryParam<DefId>) -> adt_def<'tcx>
pub fn adt_def(self, key: impl IntoQueryParam<DefId>) -> adt_def<'tcx>
[query description - consider adding a doc-comment!] computing ADT definition for tcx.def_path_str(key)
sourcepub fn adt_destructor(
self,
key: impl IntoQueryParam<DefId>
) -> adt_destructor<'tcx>
pub fn adt_destructor(
self,
key: impl IntoQueryParam<DefId>
) -> adt_destructor<'tcx>
[query description - consider adding a doc-comment!] computing Drop
impl for tcx.def_path_str(key)
sourcepub fn adt_sized_constraint(
self,
key: impl IntoQueryParam<DefId>
) -> adt_sized_constraint<'tcx>
pub fn adt_sized_constraint(
self,
key: impl IntoQueryParam<DefId>
) -> adt_sized_constraint<'tcx>
[query description - consider adding a doc-comment!] computing Sized
constraints for tcx.def_path_str(key)
sourcepub fn adt_dtorck_constraint(
self,
key: impl IntoQueryParam<DefId>
) -> adt_dtorck_constraint<'tcx>
pub fn adt_dtorck_constraint(
self,
key: impl IntoQueryParam<DefId>
) -> adt_dtorck_constraint<'tcx>
[query description - consider adding a doc-comment!] computing drop-check constraints for tcx.def_path_str(key)
sourcepub fn constness(self, key: impl IntoQueryParam<DefId>) -> constness<'tcx>
pub fn constness(self, key: impl IntoQueryParam<DefId>) -> constness<'tcx>
Returns true
if this is a const fn, use the is_const_fn
to know whether your crate
actually sees it as const fn (e.g., the const-fn-ness might be unstable and you might
not have the feature gate active).
Do not call this function manually. It is only meant to cache the base data for the
is_const_fn
function. Consider using is_const_fn
or is_const_fn_raw
instead.
sourcepub fn asyncness(self, key: impl IntoQueryParam<DefId>) -> asyncness<'tcx>
pub fn asyncness(self, key: impl IntoQueryParam<DefId>) -> asyncness<'tcx>
[query description - consider adding a doc-comment!] checking if the function is async: tcx.def_path_str(key)
sourcepub fn is_promotable_const_fn(
self,
key: impl IntoQueryParam<DefId>
) -> is_promotable_const_fn<'tcx>
pub fn is_promotable_const_fn(
self,
key: impl IntoQueryParam<DefId>
) -> is_promotable_const_fn<'tcx>
Returns true
if calls to the function may be promoted.
This is either because the function is e.g., a tuple-struct or tuple-variant
constructor, or because it has the #[rustc_promotable]
attribute. The attribute should
be removed in the future in favour of some form of check which figures out whether the
function does not inspect the bits of any of its arguments (so is essentially just a
constructor function).
sourcepub fn is_foreign_item(
self,
key: impl IntoQueryParam<DefId>
) -> is_foreign_item<'tcx>
pub fn is_foreign_item(
self,
key: impl IntoQueryParam<DefId>
) -> is_foreign_item<'tcx>
Returns true
if this is a foreign item (i.e., linked via extern { ... }
).
sourcepub fn generator_kind(
self,
key: impl IntoQueryParam<DefId>
) -> generator_kind<'tcx>
pub fn generator_kind(
self,
key: impl IntoQueryParam<DefId>
) -> generator_kind<'tcx>
Returns Some(generator_kind)
if the node pointed to by def_id
is a generator.
sourcepub fn crate_variances(self, key: ()) -> crate_variances<'tcx>
pub fn crate_variances(self, key: ()) -> crate_variances<'tcx>
Gets a map with the variance of every item; use item_variance
instead.
sourcepub fn variances_of(self, key: impl IntoQueryParam<DefId>) -> variances_of<'tcx>
pub fn variances_of(self, key: impl IntoQueryParam<DefId>) -> variances_of<'tcx>
Maps from the DefId
of a type or region parameter to its (inferred) variance.
sourcepub fn inferred_outlives_crate(self, key: ()) -> inferred_outlives_crate<'tcx>
pub fn inferred_outlives_crate(self, key: ()) -> inferred_outlives_crate<'tcx>
Maps from thee DefId
of a type to its (inferred) outlives.
sourcepub fn associated_item_def_ids(
self,
key: impl IntoQueryParam<DefId>
) -> associated_item_def_ids<'tcx>
pub fn associated_item_def_ids(
self,
key: impl IntoQueryParam<DefId>
) -> associated_item_def_ids<'tcx>
Maps from an impl/trait DefId
to a list of the DefId
s of its items.
sourcepub fn associated_item(
self,
key: impl IntoQueryParam<DefId>
) -> associated_item<'tcx>
pub fn associated_item(
self,
key: impl IntoQueryParam<DefId>
) -> associated_item<'tcx>
Maps from a trait item to the trait item “descriptor”.
sourcepub fn associated_items(
self,
key: impl IntoQueryParam<DefId>
) -> associated_items<'tcx>
pub fn associated_items(
self,
key: impl IntoQueryParam<DefId>
) -> associated_items<'tcx>
Collects the associated items defined on a trait or impl.
sourcepub fn impl_item_implementor_ids(
self,
key: impl IntoQueryParam<DefId>
) -> impl_item_implementor_ids<'tcx>
pub fn impl_item_implementor_ids(
self,
key: impl IntoQueryParam<DefId>
) -> impl_item_implementor_ids<'tcx>
Maps from associated items on a trait to the corresponding associated
item on the impl specified by impl_id
.
For example, with the following code
struct Type {}
// DefId
trait Trait { // trait_id
fn f(); // trait_f
fn g() {} // trait_g
}
impl Trait for Type { // impl_id
fn f() {} // impl_f
fn g() {} // impl_g
}
The map returned for tcx.impl_item_implementor_ids(impl_id)
would be
{ trait_f: impl_f, trait_g: impl_g }
sourcepub fn impl_trait_ref(
self,
key: impl IntoQueryParam<DefId>
) -> impl_trait_ref<'tcx>
pub fn impl_trait_ref(
self,
key: impl IntoQueryParam<DefId>
) -> impl_trait_ref<'tcx>
Given an impl_id
, return the trait it implements.
Return None
if this is an inherent impl.
sourcepub fn impl_polarity(
self,
key: impl IntoQueryParam<DefId>
) -> impl_polarity<'tcx>
pub fn impl_polarity(
self,
key: impl IntoQueryParam<DefId>
) -> impl_polarity<'tcx>
[query description - consider adding a doc-comment!] computing implementation polarity of tcx.def_path_str(impl_id)
sourcepub fn issue33140_self_ty(
self,
key: impl IntoQueryParam<DefId>
) -> issue33140_self_ty<'tcx>
pub fn issue33140_self_ty(
self,
key: impl IntoQueryParam<DefId>
) -> issue33140_self_ty<'tcx>
[query description - consider adding a doc-comment!] computing Self type wrt issue #33140 tcx.def_path_str(key)
sourcepub fn inherent_impls(
self,
key: impl IntoQueryParam<DefId>
) -> inherent_impls<'tcx>
pub fn inherent_impls(
self,
key: impl IntoQueryParam<DefId>
) -> inherent_impls<'tcx>
Maps a DefId
of a type to a list of its inherent impls.
Contains implementations of methods that are inherent to a type.
Methods in these implementations don’t need to be exported.
sourcepub fn incoherent_impls(self, key: SimplifiedType) -> incoherent_impls<'tcx>
pub fn incoherent_impls(self, key: SimplifiedType) -> incoherent_impls<'tcx>
[query description - consider adding a doc-comment!] collecting all inherent impls for {:?}
sourcepub fn unsafety_check_result(
self,
key: LocalDefId
) -> unsafety_check_result<'tcx>
pub fn unsafety_check_result(
self,
key: LocalDefId
) -> unsafety_check_result<'tcx>
The result of unsafety-checking this LocalDefId
.
sourcepub fn unsafety_check_result_for_const_arg(
self,
key: (LocalDefId, DefId)
) -> unsafety_check_result_for_const_arg<'tcx>
pub fn unsafety_check_result_for_const_arg(
self,
key: (LocalDefId, DefId)
) -> unsafety_check_result_for_const_arg<'tcx>
[query description - consider adding a doc-comment!] unsafety-checking the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn thir_check_unsafety(self, key: LocalDefId) -> thir_check_unsafety<'tcx>
pub fn thir_check_unsafety(self, key: LocalDefId) -> thir_check_unsafety<'tcx>
Unsafety-check this LocalDefId
with THIR unsafeck. This should be
used with -Zthir-unsafeck
.
sourcepub fn thir_check_unsafety_for_const_arg(
self,
key: (LocalDefId, DefId)
) -> thir_check_unsafety_for_const_arg<'tcx>
pub fn thir_check_unsafety_for_const_arg(
self,
key: (LocalDefId, DefId)
) -> thir_check_unsafety_for_const_arg<'tcx>
[query description - consider adding a doc-comment!] unsafety-checking the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn unsafe_derive_on_repr_packed(
self,
key: LocalDefId
) -> unsafe_derive_on_repr_packed<'tcx>
pub fn unsafe_derive_on_repr_packed(
self,
key: LocalDefId
) -> unsafe_derive_on_repr_packed<'tcx>
HACK: when evaluated, this reports an “unsafe derive on repr(packed)” error.
Unsafety checking is executed for each method separately, but we only want to emit this error once per derive. As there are some impls with multiple methods, we use a query for deduplication.
sourcepub fn assumed_wf_types(
self,
key: impl IntoQueryParam<DefId>
) -> assumed_wf_types<'tcx>
pub fn assumed_wf_types(
self,
key: impl IntoQueryParam<DefId>
) -> assumed_wf_types<'tcx>
Returns the types assumed to be well formed while “inside” of the given item.
Note that we’ve liberated the late bound regions of function signatures, so this can not be used to check whether these types are well formed.
sourcepub fn fn_sig(self, key: impl IntoQueryParam<DefId>) -> fn_sig<'tcx>
pub fn fn_sig(self, key: impl IntoQueryParam<DefId>) -> fn_sig<'tcx>
Computes the signature of the function.
sourcepub fn lint_mod(self, key: LocalDefId) -> lint_mod<'tcx>
pub fn lint_mod(self, key: LocalDefId) -> lint_mod<'tcx>
Performs lint checking for the module.
sourcepub fn check_mod_attrs(self, key: LocalDefId) -> check_mod_attrs<'tcx>
pub fn check_mod_attrs(self, key: LocalDefId) -> check_mod_attrs<'tcx>
Checks the attributes in the module.
sourcepub fn check_mod_unstable_api_usage(
self,
key: LocalDefId
) -> check_mod_unstable_api_usage<'tcx>
pub fn check_mod_unstable_api_usage(
self,
key: LocalDefId
) -> check_mod_unstable_api_usage<'tcx>
Checks for uses of unstable APIs in the module.
sourcepub fn check_mod_const_bodies(
self,
key: LocalDefId
) -> check_mod_const_bodies<'tcx>
pub fn check_mod_const_bodies(
self,
key: LocalDefId
) -> check_mod_const_bodies<'tcx>
Checks the const bodies in the module for illegal operations (e.g. if
or loop
).
sourcepub fn check_mod_loops(self, key: LocalDefId) -> check_mod_loops<'tcx>
pub fn check_mod_loops(self, key: LocalDefId) -> check_mod_loops<'tcx>
Checks the loops in the module.
sourcepub fn check_mod_naked_functions(
self,
key: LocalDefId
) -> check_mod_naked_functions<'tcx>
pub fn check_mod_naked_functions(
self,
key: LocalDefId
) -> check_mod_naked_functions<'tcx>
[query description - consider adding a doc-comment!] checking naked functions in describe_as_module(key, tcx)
sourcepub fn check_mod_item_types(self, key: LocalDefId) -> check_mod_item_types<'tcx>
pub fn check_mod_item_types(self, key: LocalDefId) -> check_mod_item_types<'tcx>
[query description - consider adding a doc-comment!] checking item types in describe_as_module(key, tcx)
sourcepub fn check_mod_privacy(self, key: LocalDefId) -> check_mod_privacy<'tcx>
pub fn check_mod_privacy(self, key: LocalDefId) -> check_mod_privacy<'tcx>
[query description - consider adding a doc-comment!] checking privacy in describe_as_module(key, tcx)
sourcepub fn check_liveness(
self,
key: impl IntoQueryParam<DefId>
) -> check_liveness<'tcx>
pub fn check_liveness(
self,
key: impl IntoQueryParam<DefId>
) -> check_liveness<'tcx>
[query description - consider adding a doc-comment!] checking liveness of variables in tcx.def_path_str(key)
sourcepub fn live_symbols_and_ignored_derived_traits(
self,
key: ()
) -> live_symbols_and_ignored_derived_traits<'tcx>
pub fn live_symbols_and_ignored_derived_traits(
self,
key: ()
) -> live_symbols_and_ignored_derived_traits<'tcx>
Return the live symbols in the crate for dead code check.
The second return value maps from ADTs to ignored derived traits (e.g. Debug and Clone) and their respective impl (i.e., part of the derive macro)
sourcepub fn check_mod_deathness(self, key: LocalDefId) -> check_mod_deathness<'tcx>
pub fn check_mod_deathness(self, key: LocalDefId) -> check_mod_deathness<'tcx>
[query description - consider adding a doc-comment!] checking deathness of variables in describe_as_module(key, tcx)
sourcepub fn check_mod_impl_wf(self, key: LocalDefId) -> check_mod_impl_wf<'tcx>
pub fn check_mod_impl_wf(self, key: LocalDefId) -> check_mod_impl_wf<'tcx>
[query description - consider adding a doc-comment!] checking that impls are well-formed in describe_as_module(key, tcx)
sourcepub fn check_mod_type_wf(self, key: LocalDefId) -> check_mod_type_wf<'tcx>
pub fn check_mod_type_wf(self, key: LocalDefId) -> check_mod_type_wf<'tcx>
[query description - consider adding a doc-comment!] checking that types are well-formed in describe_as_module(key, tcx)
sourcepub fn collect_mod_item_types(
self,
key: LocalDefId
) -> collect_mod_item_types<'tcx>
pub fn collect_mod_item_types(
self,
key: LocalDefId
) -> collect_mod_item_types<'tcx>
[query description - consider adding a doc-comment!] collecting item types in describe_as_module(key, tcx)
sourcepub fn coerce_unsized_info(
self,
key: impl IntoQueryParam<DefId>
) -> coerce_unsized_info<'tcx>
pub fn coerce_unsized_info(
self,
key: impl IntoQueryParam<DefId>
) -> coerce_unsized_info<'tcx>
Caches CoerceUnsized
kinds for impls on custom types.
sourcepub fn typeck_item_bodies(self, key: ()) -> typeck_item_bodies<'tcx>
pub fn typeck_item_bodies(self, key: ()) -> typeck_item_bodies<'tcx>
[query description - consider adding a doc-comment!] type-checking all item bodies
sourcepub fn typeck(self, key: LocalDefId) -> typeck<'tcx>
pub fn typeck(self, key: LocalDefId) -> typeck<'tcx>
[query description - consider adding a doc-comment!] type-checking tcx.def_path_str(key.to_def_id())
sourcepub fn typeck_const_arg(self, key: (LocalDefId, DefId)) -> typeck_const_arg<'tcx>
pub fn typeck_const_arg(self, key: (LocalDefId, DefId)) -> typeck_const_arg<'tcx>
[query description - consider adding a doc-comment!] type-checking the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn diagnostic_only_typeck(
self,
key: LocalDefId
) -> diagnostic_only_typeck<'tcx>
pub fn diagnostic_only_typeck(
self,
key: LocalDefId
) -> diagnostic_only_typeck<'tcx>
[query description - consider adding a doc-comment!] type-checking tcx.def_path_str(key.to_def_id())
sourcepub fn used_trait_imports(self, key: LocalDefId) -> used_trait_imports<'tcx>
pub fn used_trait_imports(self, key: LocalDefId) -> used_trait_imports<'tcx>
[query description - consider adding a doc-comment!] finding used_trait_imports tcx.def_path_str(key.to_def_id())
sourcepub fn has_typeck_results(
self,
key: impl IntoQueryParam<DefId>
) -> has_typeck_results<'tcx>
pub fn has_typeck_results(
self,
key: impl IntoQueryParam<DefId>
) -> has_typeck_results<'tcx>
[query description - consider adding a doc-comment!] checking whether tcx.def_path_str(def_id)
has a body
sourcepub fn coherent_trait(
self,
key: impl IntoQueryParam<DefId>
) -> coherent_trait<'tcx>
pub fn coherent_trait(
self,
key: impl IntoQueryParam<DefId>
) -> coherent_trait<'tcx>
[query description - consider adding a doc-comment!] coherence checking all impls of trait tcx.def_path_str(def_id)
sourcepub fn mir_borrowck(self, key: LocalDefId) -> mir_borrowck<'tcx>
pub fn mir_borrowck(self, key: LocalDefId) -> mir_borrowck<'tcx>
Borrow-checks the function body. If this is a closure, returns additional requirements that the closure’s creator must verify.
sourcepub fn mir_borrowck_const_arg(
self,
key: (LocalDefId, DefId)
) -> mir_borrowck_const_arg<'tcx>
pub fn mir_borrowck_const_arg(
self,
key: (LocalDefId, DefId)
) -> mir_borrowck_const_arg<'tcx>
[query description - consider adding a doc-comment!] borrow-checking the const argument tcx.def_path_str(key.0.to_def_id())
sourcepub fn crate_inherent_impls(self, key: ()) -> crate_inherent_impls<'tcx>
pub fn crate_inherent_impls(self, key: ()) -> crate_inherent_impls<'tcx>
Gets a complete map from all types to their inherent impls. Not meant to be used directly outside of coherence.
sourcepub fn crate_inherent_impls_overlap_check(
self,
key: ()
) -> crate_inherent_impls_overlap_check<'tcx>
pub fn crate_inherent_impls_overlap_check(
self,
key: ()
) -> crate_inherent_impls_overlap_check<'tcx>
Checks all types in the crate for overlap in their inherent impls. Reports errors. Not meant to be used directly outside of coherence.
sourcepub fn orphan_check_impl(self, key: LocalDefId) -> orphan_check_impl<'tcx>
pub fn orphan_check_impl(self, key: LocalDefId) -> orphan_check_impl<'tcx>
Checks whether all impls in the crate pass the overlap check, returning which impls fail it. If all impls are correct, the returned slice is empty.
sourcepub fn mir_callgraph_reachable(
self,
key: (Instance<'tcx>, LocalDefId)
) -> mir_callgraph_reachable<'tcx>
pub fn mir_callgraph_reachable(
self,
key: (Instance<'tcx>, LocalDefId)
) -> mir_callgraph_reachable<'tcx>
Check whether the function has any recursion that could cause the inliner to trigger a cycle. Returns the call stack causing the cycle. The call stack does not contain the current function, just all intermediate functions.
sourcepub fn mir_inliner_callees(
self,
key: InstanceDef<'tcx>
) -> mir_inliner_callees<'tcx>
pub fn mir_inliner_callees(
self,
key: InstanceDef<'tcx>
) -> mir_inliner_callees<'tcx>
Obtain all the calls into other local functions
sourcepub fn eval_to_allocation_raw(
self,
key: ParamEnvAnd<'tcx, GlobalId<'tcx>>
) -> eval_to_allocation_raw<'tcx>
pub fn eval_to_allocation_raw(
self,
key: ParamEnvAnd<'tcx, GlobalId<'tcx>>
) -> eval_to_allocation_raw<'tcx>
Evaluates a constant and returns the computed allocation.
Do not use this directly, use the tcx.eval_static_initializer
wrapper.
sourcepub fn eval_to_const_value_raw(
self,
key: ParamEnvAnd<'tcx, GlobalId<'tcx>>
) -> eval_to_const_value_raw<'tcx>
pub fn eval_to_const_value_raw(
self,
key: ParamEnvAnd<'tcx, GlobalId<'tcx>>
) -> eval_to_const_value_raw<'tcx>
Evaluates const items or anonymous constants (such as enum variant explicit discriminants or array lengths) into a representation suitable for the type system and const generics.
Do not use this directly, use one of the following wrappers: tcx.const_eval_poly
,
tcx.const_eval_resolve
, tcx.const_eval_instance
, or tcx.const_eval_global_id
.
sourcepub fn eval_to_valtree(
self,
key: ParamEnvAnd<'tcx, GlobalId<'tcx>>
) -> eval_to_valtree<'tcx>
pub fn eval_to_valtree(
self,
key: ParamEnvAnd<'tcx, GlobalId<'tcx>>
) -> eval_to_valtree<'tcx>
Evaluate a constant and convert it to a type level constant or
return None
if that is not possible.
sourcepub fn valtree_to_const_val(
self,
key: (Ty<'tcx>, ValTree<'tcx>)
) -> valtree_to_const_val<'tcx>
pub fn valtree_to_const_val(
self,
key: (Ty<'tcx>, ValTree<'tcx>)
) -> valtree_to_const_val<'tcx>
Converts a type level constant value into ConstValue
sourcepub fn destructure_const(self, key: Const<'tcx>) -> destructure_const<'tcx>
pub fn destructure_const(self, key: Const<'tcx>) -> destructure_const<'tcx>
Destructures array, ADT or tuple constants into the constants of their fields.
sourcepub fn try_destructure_mir_constant(
self,
key: ParamEnvAnd<'tcx, ConstantKind<'tcx>>
) -> try_destructure_mir_constant<'tcx>
pub fn try_destructure_mir_constant(
self,
key: ParamEnvAnd<'tcx, ConstantKind<'tcx>>
) -> try_destructure_mir_constant<'tcx>
Tries to destructure an mir::ConstantKind
ADT or array into its variant index
and its field values.
sourcepub fn deref_mir_constant(
self,
key: ParamEnvAnd<'tcx, ConstantKind<'tcx>>
) -> deref_mir_constant<'tcx>
pub fn deref_mir_constant(
self,
key: ParamEnvAnd<'tcx, ConstantKind<'tcx>>
) -> deref_mir_constant<'tcx>
Dereference a constant reference or raw pointer and turn the result into a constant again.
sourcepub fn const_caller_location(
self,
key: (Symbol, u32, u32)
) -> const_caller_location<'tcx>
pub fn const_caller_location(
self,
key: (Symbol, u32, u32)
) -> const_caller_location<'tcx>
[query description - consider adding a doc-comment!] getting a &core::panic::Location referring to a span
sourcepub fn lit_to_const(self, key: LitToConstInput<'tcx>) -> lit_to_const<'tcx>
pub fn lit_to_const(self, key: LitToConstInput<'tcx>) -> lit_to_const<'tcx>
[query description - consider adding a doc-comment!] converting literal to const
sourcepub fn lit_to_mir_constant(
self,
key: LitToConstInput<'tcx>
) -> lit_to_mir_constant<'tcx>
pub fn lit_to_mir_constant(
self,
key: LitToConstInput<'tcx>
) -> lit_to_mir_constant<'tcx>
[query description - consider adding a doc-comment!] converting literal to mir constant
sourcepub fn check_match(self, key: impl IntoQueryParam<DefId>) -> check_match<'tcx>
pub fn check_match(self, key: impl IntoQueryParam<DefId>) -> check_match<'tcx>
[query description - consider adding a doc-comment!] match-checking tcx.def_path_str(key)
sourcepub fn effective_visibilities(self, key: ()) -> effective_visibilities<'tcx>
pub fn effective_visibilities(self, key: ()) -> effective_visibilities<'tcx>
Performs part of the privacy check and computes effective visibilities.
sourcepub fn check_private_in_public(self, key: ()) -> check_private_in_public<'tcx>
pub fn check_private_in_public(self, key: ()) -> check_private_in_public<'tcx>
[query description - consider adding a doc-comment!] checking for private elements in public interfaces
sourcepub fn reachable_set(self, key: ()) -> reachable_set<'tcx>
pub fn reachable_set(self, key: ()) -> reachable_set<'tcx>
[query description - consider adding a doc-comment!] reachability
sourcepub fn region_scope_tree(
self,
key: impl IntoQueryParam<DefId>
) -> region_scope_tree<'tcx>
pub fn region_scope_tree(
self,
key: impl IntoQueryParam<DefId>
) -> region_scope_tree<'tcx>
Per-body region::ScopeTree
. The DefId
should be the owner DefId
for the body;
in the case of closures, this will be redirected to the enclosing function.
sourcepub fn mir_shims(self, key: InstanceDef<'tcx>) -> mir_shims<'tcx>
pub fn mir_shims(self, key: InstanceDef<'tcx>) -> mir_shims<'tcx>
Generates a MIR body for the shim.
sourcepub fn symbol_name(self, key: Instance<'tcx>) -> symbol_name<'tcx>
pub fn symbol_name(self, key: Instance<'tcx>) -> symbol_name<'tcx>
The symbol_name
query provides the symbol name for calling a
given instance from the local crate. In particular, it will also
look up the correct symbol name of instances from upstream crates.
sourcepub fn opt_def_kind(self, key: impl IntoQueryParam<DefId>) -> opt_def_kind<'tcx>
pub fn opt_def_kind(self, key: impl IntoQueryParam<DefId>) -> opt_def_kind<'tcx>
[query description - consider adding a doc-comment!] looking up definition kind of tcx.def_path_str(def_id)
sourcepub fn def_span(self, key: impl IntoQueryParam<DefId>) -> def_span<'tcx>
pub fn def_span(self, key: impl IntoQueryParam<DefId>) -> def_span<'tcx>
Gets the span for the definition.
sourcepub fn def_ident_span(
self,
key: impl IntoQueryParam<DefId>
) -> def_ident_span<'tcx>
pub fn def_ident_span(
self,
key: impl IntoQueryParam<DefId>
) -> def_ident_span<'tcx>
Gets the span for the identifier of the definition.
sourcepub fn lookup_stability(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_stability<'tcx>
pub fn lookup_stability(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_stability<'tcx>
[query description - consider adding a doc-comment!] looking up stability of tcx.def_path_str(def_id)
sourcepub fn lookup_const_stability(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_const_stability<'tcx>
pub fn lookup_const_stability(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_const_stability<'tcx>
[query description - consider adding a doc-comment!] looking up const stability of tcx.def_path_str(def_id)
sourcepub fn lookup_default_body_stability(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_default_body_stability<'tcx>
pub fn lookup_default_body_stability(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_default_body_stability<'tcx>
[query description - consider adding a doc-comment!] looking up default body stability of tcx.def_path_str(def_id)
sourcepub fn should_inherit_track_caller(
self,
key: impl IntoQueryParam<DefId>
) -> should_inherit_track_caller<'tcx>
pub fn should_inherit_track_caller(
self,
key: impl IntoQueryParam<DefId>
) -> should_inherit_track_caller<'tcx>
[query description - consider adding a doc-comment!] computing should_inherit_track_caller of tcx.def_path_str(def_id)
sourcepub fn lookup_deprecation_entry(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_deprecation_entry<'tcx>
pub fn lookup_deprecation_entry(
self,
key: impl IntoQueryParam<DefId>
) -> lookup_deprecation_entry<'tcx>
[query description - consider adding a doc-comment!] checking whether tcx.def_path_str(def_id)
is deprecated
Determines whether an item is annotated with doc(hidden)
.
sourcepub fn is_doc_notable_trait(
self,
key: impl IntoQueryParam<DefId>
) -> is_doc_notable_trait<'tcx>
pub fn is_doc_notable_trait(
self,
key: impl IntoQueryParam<DefId>
) -> is_doc_notable_trait<'tcx>
Determines whether an item is annotated with doc(notable_trait)
.
sourcepub fn item_attrs(self, key: impl IntoQueryParam<DefId>) -> item_attrs<'tcx>
pub fn item_attrs(self, key: impl IntoQueryParam<DefId>) -> item_attrs<'tcx>
Returns the attributes on the item at def_id
.
Do not use this directly, use tcx.get_attrs
instead.
sourcepub fn codegen_fn_attrs(
self,
key: impl IntoQueryParam<DefId>
) -> codegen_fn_attrs<'tcx>
pub fn codegen_fn_attrs(
self,
key: impl IntoQueryParam<DefId>
) -> codegen_fn_attrs<'tcx>
[query description - consider adding a doc-comment!] computing codegen attributes of tcx.def_path_str(def_id)
sourcepub fn asm_target_features(
self,
key: impl IntoQueryParam<DefId>
) -> asm_target_features<'tcx>
pub fn asm_target_features(
self,
key: impl IntoQueryParam<DefId>
) -> asm_target_features<'tcx>
[query description - consider adding a doc-comment!] computing target features for inline asm of tcx.def_path_str(def_id)
sourcepub fn fn_arg_names(self, key: impl IntoQueryParam<DefId>) -> fn_arg_names<'tcx>
pub fn fn_arg_names(self, key: impl IntoQueryParam<DefId>) -> fn_arg_names<'tcx>
[query description - consider adding a doc-comment!] looking up function parameter names for tcx.def_path_str(def_id)
sourcepub fn rendered_const(
self,
key: impl IntoQueryParam<DefId>
) -> rendered_const<'tcx>
pub fn rendered_const(
self,
key: impl IntoQueryParam<DefId>
) -> rendered_const<'tcx>
Gets the rendered value of the specified constant or associated constant. Used by rustdoc.
sourcepub fn impl_parent(self, key: impl IntoQueryParam<DefId>) -> impl_parent<'tcx>
pub fn impl_parent(self, key: impl IntoQueryParam<DefId>) -> impl_parent<'tcx>
[query description - consider adding a doc-comment!] computing specialization parent impl of tcx.def_path_str(def_id)
sourcepub fn is_ctfe_mir_available(
self,
key: impl IntoQueryParam<DefId>
) -> is_ctfe_mir_available<'tcx>
pub fn is_ctfe_mir_available(
self,
key: impl IntoQueryParam<DefId>
) -> is_ctfe_mir_available<'tcx>
[query description - consider adding a doc-comment!] checking if item has CTFE MIR available: tcx.def_path_str(key)
sourcepub fn is_mir_available(
self,
key: impl IntoQueryParam<DefId>
) -> is_mir_available<'tcx>
pub fn is_mir_available(
self,
key: impl IntoQueryParam<DefId>
) -> is_mir_available<'tcx>
[query description - consider adding a doc-comment!] checking if item has MIR available: tcx.def_path_str(key)
sourcepub fn own_existential_vtable_entries(
self,
key: impl IntoQueryParam<DefId>
) -> own_existential_vtable_entries<'tcx>
pub fn own_existential_vtable_entries(
self,
key: impl IntoQueryParam<DefId>
) -> own_existential_vtable_entries<'tcx>
[query description - consider adding a doc-comment!] finding all existential vtable entries for trait tcx.def_path_str(key)
sourcepub fn vtable_entries(self, key: PolyTraitRef<'tcx>) -> vtable_entries<'tcx>
pub fn vtable_entries(self, key: PolyTraitRef<'tcx>) -> vtable_entries<'tcx>
[query description - consider adding a doc-comment!] finding all vtable entries for trait tcx.def_path_str(key.def_id())
sourcepub fn vtable_trait_upcasting_coercion_new_vptr_slot(
self,
key: (Ty<'tcx>, Ty<'tcx>)
) -> vtable_trait_upcasting_coercion_new_vptr_slot<'tcx>
pub fn vtable_trait_upcasting_coercion_new_vptr_slot(
self,
key: (Ty<'tcx>, Ty<'tcx>)
) -> vtable_trait_upcasting_coercion_new_vptr_slot<'tcx>
[query description - consider adding a doc-comment!] finding the slot within vtable for trait object key.1
vtable ptr during trait upcasting coercion from key.0
vtable
sourcepub fn vtable_allocation(
self,
key: (Ty<'tcx>, Option<PolyExistentialTraitRef<'tcx>>)
) -> vtable_allocation<'tcx>
pub fn vtable_allocation(
self,
key: (Ty<'tcx>, Option<PolyExistentialTraitRef<'tcx>>)
) -> vtable_allocation<'tcx>
[query description - consider adding a doc-comment!] vtable const allocation for < key.0
as key.1.map(| trait_ref | format! ("{}", trait_ref)).unwrap_or("_".to_owned())
>
sourcepub fn codegen_select_candidate(
self,
key: (ParamEnv<'tcx>, PolyTraitRef<'tcx>)
) -> codegen_select_candidate<'tcx>
pub fn codegen_select_candidate(
self,
key: (ParamEnv<'tcx>, PolyTraitRef<'tcx>)
) -> codegen_select_candidate<'tcx>
[query description - consider adding a doc-comment!] computing candidate for key.1
sourcepub fn all_local_trait_impls(self, key: ()) -> all_local_trait_impls<'tcx>
pub fn all_local_trait_impls(self, key: ()) -> all_local_trait_impls<'tcx>
Return all impl
blocks in the current crate.
sourcepub fn trait_impls_of(
self,
key: impl IntoQueryParam<DefId>
) -> trait_impls_of<'tcx>
pub fn trait_impls_of(
self,
key: impl IntoQueryParam<DefId>
) -> trait_impls_of<'tcx>
Given a trait trait_id
, return all known impl
blocks.
sourcepub fn specialization_graph_of(
self,
key: impl IntoQueryParam<DefId>
) -> specialization_graph_of<'tcx>
pub fn specialization_graph_of(
self,
key: impl IntoQueryParam<DefId>
) -> specialization_graph_of<'tcx>
[query description - consider adding a doc-comment!] building specialization graph of trait tcx.def_path_str(trait_id)
sourcepub fn object_safety_violations(
self,
key: impl IntoQueryParam<DefId>
) -> object_safety_violations<'tcx>
pub fn object_safety_violations(
self,
key: impl IntoQueryParam<DefId>
) -> object_safety_violations<'tcx>
[query description - consider adding a doc-comment!] determining object safety of trait tcx.def_path_str(trait_id)
sourcepub fn param_env(self, key: impl IntoQueryParam<DefId>) -> param_env<'tcx>
pub fn param_env(self, key: impl IntoQueryParam<DefId>) -> param_env<'tcx>
Gets the ParameterEnvironment for a given item; this environment
will be in “user-facing” mode, meaning that it is suitable for
type-checking etc, and it does not normalize specializable
associated types. This is almost always what you want,
unless you are doing MIR optimizations, in which case you
might want to use reveal_all()
method to change modes.
sourcepub fn param_env_reveal_all_normalized(
self,
key: impl IntoQueryParam<DefId>
) -> param_env_reveal_all_normalized<'tcx>
pub fn param_env_reveal_all_normalized(
self,
key: impl IntoQueryParam<DefId>
) -> param_env_reveal_all_normalized<'tcx>
Like param_env
, but returns the ParamEnv
in Reveal::All
mode.
Prefer this over tcx.param_env(def_id).with_reveal_all_normalized(tcx)
,
as this method is more efficient.
sourcepub fn is_copy_raw(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> is_copy_raw<'tcx>
pub fn is_copy_raw(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> is_copy_raw<'tcx>
Trait selection queries. These are best used by invoking ty.is_copy_modulo_regions()
,
ty.is_copy()
, etc, since that will prune the environment where possible.
sourcepub fn is_sized_raw(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> is_sized_raw<'tcx>
pub fn is_sized_raw(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> is_sized_raw<'tcx>
Query backing Ty::is_sized
.
sourcepub fn is_freeze_raw(
self,
key: ParamEnvAnd<'tcx, Ty<'tcx>>
) -> is_freeze_raw<'tcx>
pub fn is_freeze_raw(
self,
key: ParamEnvAnd<'tcx, Ty<'tcx>>
) -> is_freeze_raw<'tcx>
Query backing Ty::is_freeze
.
sourcepub fn is_unpin_raw(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> is_unpin_raw<'tcx>
pub fn is_unpin_raw(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> is_unpin_raw<'tcx>
Query backing Ty::is_unpin
.
sourcepub fn needs_drop_raw(
self,
key: ParamEnvAnd<'tcx, Ty<'tcx>>
) -> needs_drop_raw<'tcx>
pub fn needs_drop_raw(
self,
key: ParamEnvAnd<'tcx, Ty<'tcx>>
) -> needs_drop_raw<'tcx>
Query backing Ty::needs_drop
.
sourcepub fn has_significant_drop_raw(
self,
key: ParamEnvAnd<'tcx, Ty<'tcx>>
) -> has_significant_drop_raw<'tcx>
pub fn has_significant_drop_raw(
self,
key: ParamEnvAnd<'tcx, Ty<'tcx>>
) -> has_significant_drop_raw<'tcx>
Query backing Ty::has_significant_drop_raw
.
sourcepub fn has_structural_eq_impls(
self,
key: Ty<'tcx>
) -> has_structural_eq_impls<'tcx>
pub fn has_structural_eq_impls(
self,
key: Ty<'tcx>
) -> has_structural_eq_impls<'tcx>
Query backing Ty::is_structural_eq_shallow
.
This is only correct for ADTs. Call is_structural_eq_shallow
to handle all types
correctly.
sourcepub fn adt_drop_tys(self, key: impl IntoQueryParam<DefId>) -> adt_drop_tys<'tcx>
pub fn adt_drop_tys(self, key: impl IntoQueryParam<DefId>) -> adt_drop_tys<'tcx>
A list of types where the ADT requires drop if and only if any of
those types require drop. If the ADT is known to always need drop
then Err(AlwaysRequiresDrop)
is returned.
sourcepub fn adt_significant_drop_tys(
self,
key: impl IntoQueryParam<DefId>
) -> adt_significant_drop_tys<'tcx>
pub fn adt_significant_drop_tys(
self,
key: impl IntoQueryParam<DefId>
) -> adt_significant_drop_tys<'tcx>
A list of types where the ADT requires drop if and only if any of those types
has significant drop. A type marked with the attribute rustc_insignificant_dtor
is considered to not be significant. A drop is significant if it is implemented
by the user or does anything that will have any observable behavior (other than
freeing up memory). If the ADT is known to have a significant destructor then
Err(AlwaysRequiresDrop)
is returned.
sourcepub fn layout_of(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> layout_of<'tcx>
pub fn layout_of(self, key: ParamEnvAnd<'tcx, Ty<'tcx>>) -> layout_of<'tcx>
Computes the layout of a type. Note that this implicitly executes in “reveal all” mode, and will normalize the input type.
sourcepub fn fn_abi_of_fn_ptr(
self,
key: ParamEnvAnd<'tcx, (PolyFnSig<'tcx>, &'tcx List<Ty<'tcx>>)>
) -> fn_abi_of_fn_ptr<'tcx>
pub fn fn_abi_of_fn_ptr(
self,
key: ParamEnvAnd<'tcx, (PolyFnSig<'tcx>, &'tcx List<Ty<'tcx>>)>
) -> fn_abi_of_fn_ptr<'tcx>
Compute a FnAbi
suitable for indirect calls, i.e. to fn
pointers.
NB: this doesn’t handle virtual calls - those should use fn_abi_of_instance
instead, where the instance is an InstanceDef::Virtual
.
sourcepub fn fn_abi_of_instance(
self,
key: ParamEnvAnd<'tcx, (Instance<'tcx>, &'tcx List<Ty<'tcx>>)>
) -> fn_abi_of_instance<'tcx>
pub fn fn_abi_of_instance(
self,
key: ParamEnvAnd<'tcx, (Instance<'tcx>, &'tcx List<Ty<'tcx>>)>
) -> fn_abi_of_instance<'tcx>
Compute a FnAbi
suitable for declaring/defining an fn
instance, and for
direct calls to an fn
.
NB: that includes virtual calls, which are represented by “direct calls”
to an InstanceDef::Virtual
instance (of <dyn Trait as Trait>::fn
).
sourcepub fn dylib_dependency_formats(
self,
key: CrateNum
) -> dylib_dependency_formats<'tcx>
pub fn dylib_dependency_formats(
self,
key: CrateNum
) -> dylib_dependency_formats<'tcx>
[query description - consider adding a doc-comment!] getting dylib dependency formats of crate
sourcepub fn dependency_formats(self, key: ()) -> dependency_formats<'tcx>
pub fn dependency_formats(self, key: ()) -> dependency_formats<'tcx>
[query description - consider adding a doc-comment!] getting the linkage format of all dependencies
sourcepub fn is_compiler_builtins(self, key: CrateNum) -> is_compiler_builtins<'tcx>
pub fn is_compiler_builtins(self, key: CrateNum) -> is_compiler_builtins<'tcx>
[query description - consider adding a doc-comment!] checking if the crate is_compiler_builtins
sourcepub fn has_global_allocator(self, key: CrateNum) -> has_global_allocator<'tcx>
pub fn has_global_allocator(self, key: CrateNum) -> has_global_allocator<'tcx>
[query description - consider adding a doc-comment!] checking if the crate has_global_allocator
sourcepub fn has_alloc_error_handler(
self,
key: CrateNum
) -> has_alloc_error_handler<'tcx>
pub fn has_alloc_error_handler(
self,
key: CrateNum
) -> has_alloc_error_handler<'tcx>
[query description - consider adding a doc-comment!] checking if the crate has_alloc_error_handler
sourcepub fn has_panic_handler(self, key: CrateNum) -> has_panic_handler<'tcx>
pub fn has_panic_handler(self, key: CrateNum) -> has_panic_handler<'tcx>
[query description - consider adding a doc-comment!] checking if the crate has_panic_handler
sourcepub fn is_profiler_runtime(self, key: CrateNum) -> is_profiler_runtime<'tcx>
pub fn is_profiler_runtime(self, key: CrateNum) -> is_profiler_runtime<'tcx>
[query description - consider adding a doc-comment!] checking if a crate is #![profiler_runtime]
sourcepub fn has_ffi_unwind_calls(self, key: LocalDefId) -> has_ffi_unwind_calls<'tcx>
pub fn has_ffi_unwind_calls(self, key: LocalDefId) -> has_ffi_unwind_calls<'tcx>
[query description - consider adding a doc-comment!] checking if tcx.def_path_str(key.to_def_id())
contains FFI-unwind calls
sourcepub fn required_panic_strategy(
self,
key: CrateNum
) -> required_panic_strategy<'tcx>
pub fn required_panic_strategy(
self,
key: CrateNum
) -> required_panic_strategy<'tcx>
[query description - consider adding a doc-comment!] getting a crate’s required panic strategy
sourcepub fn panic_in_drop_strategy(
self,
key: CrateNum
) -> panic_in_drop_strategy<'tcx>
pub fn panic_in_drop_strategy(
self,
key: CrateNum
) -> panic_in_drop_strategy<'tcx>
[query description - consider adding a doc-comment!] getting a crate’s configured panic-in-drop strategy
sourcepub fn is_no_builtins(self, key: CrateNum) -> is_no_builtins<'tcx>
pub fn is_no_builtins(self, key: CrateNum) -> is_no_builtins<'tcx>
[query description - consider adding a doc-comment!] getting whether a crate has #![no_builtins]
sourcepub fn symbol_mangling_version(
self,
key: CrateNum
) -> symbol_mangling_version<'tcx>
pub fn symbol_mangling_version(
self,
key: CrateNum
) -> symbol_mangling_version<'tcx>
[query description - consider adding a doc-comment!] getting a crate’s symbol mangling version
sourcepub fn extern_crate(self, key: impl IntoQueryParam<DefId>) -> extern_crate<'tcx>
pub fn extern_crate(self, key: impl IntoQueryParam<DefId>) -> extern_crate<'tcx>
[query description - consider adding a doc-comment!] getting crate’s ExternCrateData
sourcepub fn specializes(self, key: (DefId, DefId)) -> specializes<'tcx>
pub fn specializes(self, key: (DefId, DefId)) -> specializes<'tcx>
[query description - consider adding a doc-comment!] computing whether impls specialize one another
sourcepub fn in_scope_traits_map(self, key: OwnerId) -> in_scope_traits_map<'tcx>
pub fn in_scope_traits_map(self, key: OwnerId) -> in_scope_traits_map<'tcx>
[query description - consider adding a doc-comment!] getting traits in scope at a block
sourcepub fn module_reexports(self, key: LocalDefId) -> module_reexports<'tcx>
pub fn module_reexports(self, key: LocalDefId) -> module_reexports<'tcx>
[query description - consider adding a doc-comment!] looking up reexports of module tcx.def_path_str(def_id.to_def_id())
sourcepub fn impl_defaultness(
self,
key: impl IntoQueryParam<DefId>
) -> impl_defaultness<'tcx>
pub fn impl_defaultness(
self,
key: impl IntoQueryParam<DefId>
) -> impl_defaultness<'tcx>
[query description - consider adding a doc-comment!] looking up whether tcx.def_path_str(def_id)
is a default impl
sourcepub fn check_well_formed(self, key: OwnerId) -> check_well_formed<'tcx>
pub fn check_well_formed(self, key: OwnerId) -> check_well_formed<'tcx>
[query description - consider adding a doc-comment!] checking that tcx.def_path_str(key.to_def_id())
is well-formed
sourcepub fn reachable_non_generics(
self,
key: CrateNum
) -> reachable_non_generics<'tcx>
pub fn reachable_non_generics(
self,
key: CrateNum
) -> reachable_non_generics<'tcx>
[query description - consider adding a doc-comment!] looking up the exported symbols of a crate
sourcepub fn is_reachable_non_generic(
self,
key: impl IntoQueryParam<DefId>
) -> is_reachable_non_generic<'tcx>
pub fn is_reachable_non_generic(
self,
key: impl IntoQueryParam<DefId>
) -> is_reachable_non_generic<'tcx>
[query description - consider adding a doc-comment!] checking whether tcx.def_path_str(def_id)
is an exported symbol
sourcepub fn is_unreachable_local_definition(
self,
key: LocalDefId
) -> is_unreachable_local_definition<'tcx>
pub fn is_unreachable_local_definition(
self,
key: LocalDefId
) -> is_unreachable_local_definition<'tcx>
[query description - consider adding a doc-comment!] checking whether tcx.def_path_str(def_id.to_def_id())
is reachable from outside the crate
sourcepub fn upstream_monomorphizations(
self,
key: ()
) -> upstream_monomorphizations<'tcx>
pub fn upstream_monomorphizations(
self,
key: ()
) -> upstream_monomorphizations<'tcx>
The entire set of monomorphizations the local crate can safely link
to because they are exported from upstream crates. Do not depend on
this directly, as its value changes anytime a monomorphization gets
added or removed in any upstream crate. Instead use the narrower
upstream_monomorphizations_for
, upstream_drop_glue_for
, or, even
better, Instance::upstream_monomorphization()
.
sourcepub fn upstream_monomorphizations_for(
self,
key: impl IntoQueryParam<DefId>
) -> upstream_monomorphizations_for<'tcx>
pub fn upstream_monomorphizations_for(
self,
key: impl IntoQueryParam<DefId>
) -> upstream_monomorphizations_for<'tcx>
Returns the set of upstream monomorphizations available for the
generic function identified by the given def_id
. The query makes
sure to make a stable selection if the same monomorphization is
available in multiple upstream crates.
You likely want to call Instance::upstream_monomorphization()
instead of invoking this query directly.
sourcepub fn upstream_drop_glue_for(
self,
key: SubstsRef<'tcx>
) -> upstream_drop_glue_for<'tcx>
pub fn upstream_drop_glue_for(
self,
key: SubstsRef<'tcx>
) -> upstream_drop_glue_for<'tcx>
Returns the upstream crate that exports drop-glue for the given
type (substs
is expected to be a single-item list containing the
type one wants drop-glue for).
This is a subset of upstream_monomorphizations_for
in order to
increase dep-tracking granularity. Otherwise adding or removing any
type with drop-glue in any upstream crate would invalidate all
functions calling drop-glue of an upstream type.
You likely want to call Instance::upstream_monomorphization()
instead of invoking this query directly.
NOTE: This query could easily be extended to also support other
common functions that have are large set of monomorphizations
(like Clone::clone
for example).
sourcepub fn foreign_modules(self, key: CrateNum) -> foreign_modules<'tcx>
pub fn foreign_modules(self, key: CrateNum) -> foreign_modules<'tcx>
Returns a list of all extern
blocks of a crate.
sourcepub fn entry_fn(self, key: ()) -> entry_fn<'tcx>
pub fn entry_fn(self, key: ()) -> entry_fn<'tcx>
Identifies the entry-point (e.g., the main
function) for a given
crate, returning None
if there is no entry point (such as for library crates).
sourcepub fn proc_macro_decls_static(self, key: ()) -> proc_macro_decls_static<'tcx>
pub fn proc_macro_decls_static(self, key: ()) -> proc_macro_decls_static<'tcx>
Finds the rustc_proc_macro_decls
item of a crate.
sourcepub fn crate_hash(self, key: CrateNum) -> crate_hash<'tcx>
pub fn crate_hash(self, key: CrateNum) -> crate_hash<'tcx>
[query description - consider adding a doc-comment!] looking up the hash a crate
sourcepub fn crate_host_hash(self, key: CrateNum) -> crate_host_hash<'tcx>
pub fn crate_host_hash(self, key: CrateNum) -> crate_host_hash<'tcx>
Gets the hash for the host proc macro. Used to support -Z dual-proc-macro.
sourcepub fn extra_filename(self, key: CrateNum) -> extra_filename<'tcx>
pub fn extra_filename(self, key: CrateNum) -> extra_filename<'tcx>
Gets the extra data to put in each output filename for a crate.
For example, compiling the foo
crate with extra-filename=-a
creates a libfoo-b.rlib
file.
sourcepub fn crate_extern_paths(self, key: CrateNum) -> crate_extern_paths<'tcx>
pub fn crate_extern_paths(self, key: CrateNum) -> crate_extern_paths<'tcx>
Gets the paths where the crate came from in the file system.
sourcepub fn implementations_of_trait(
self,
key: (CrateNum, DefId)
) -> implementations_of_trait<'tcx>
pub fn implementations_of_trait(
self,
key: (CrateNum, DefId)
) -> implementations_of_trait<'tcx>
Given a crate and a trait, look up all impls of that trait in the crate.
Return (impl_id, self_ty)
.
sourcepub fn crate_incoherent_impls(
self,
key: (CrateNum, SimplifiedType)
) -> crate_incoherent_impls<'tcx>
pub fn crate_incoherent_impls(
self,
key: (CrateNum, SimplifiedType)
) -> crate_incoherent_impls<'tcx>
Collects all incoherent impls for the given crate and type.
Do not call this directly, but instead use the incoherent_impls
query.
This query is only used to get the data necessary for that query.
sourcepub fn native_library(
self,
key: impl IntoQueryParam<DefId>
) -> native_library<'tcx>
pub fn native_library(
self,
key: impl IntoQueryParam<DefId>
) -> native_library<'tcx>
Get the corresponding native library from the native_libraries
query
sourcepub fn resolve_lifetimes(self, key: OwnerId) -> resolve_lifetimes<'tcx>
pub fn resolve_lifetimes(self, key: OwnerId) -> resolve_lifetimes<'tcx>
Does lifetime resolution on items. Importantly, we can’t resolve lifetimes directly on things like trait methods, because of trait params. See `rustc_resolve::late::lifetimes for details.
sourcepub fn named_region_map(self, key: OwnerId) -> named_region_map<'tcx>
pub fn named_region_map(self, key: OwnerId) -> named_region_map<'tcx>
[query description - consider adding a doc-comment!] looking up a named region
sourcepub fn is_late_bound_map(self, key: LocalDefId) -> is_late_bound_map<'tcx>
pub fn is_late_bound_map(self, key: LocalDefId) -> is_late_bound_map<'tcx>
[query description - consider adding a doc-comment!] testing if a region is late bound
sourcepub fn object_lifetime_default(
self,
key: impl IntoQueryParam<DefId>
) -> object_lifetime_default<'tcx>
pub fn object_lifetime_default(
self,
key: impl IntoQueryParam<DefId>
) -> object_lifetime_default<'tcx>
For a given item’s generic parameter, gets the default lifetimes to be used
for each parameter if a trait object were to be passed for that parameter.
For example, for T
in struct Foo<'a, T>
, this would be 'static
.
For T
in struct Foo<'a, T: 'a>
, this would instead be 'a
.
This query will panic if passed something that is not a type parameter.
sourcepub fn late_bound_vars_map(self, key: OwnerId) -> late_bound_vars_map<'tcx>
pub fn late_bound_vars_map(self, key: OwnerId) -> late_bound_vars_map<'tcx>
[query description - consider adding a doc-comment!] looking up late bound vars
sourcepub fn visibility(self, key: impl IntoQueryParam<DefId>) -> visibility<'tcx>
pub fn visibility(self, key: impl IntoQueryParam<DefId>) -> visibility<'tcx>
Computes the visibility of the provided def_id
.
If the item from the def_id
doesn’t have a visibility, it will panic. For example
a generic type parameter will panic if you call this method on it:
use std::fmt::Debug;
pub trait Foo<T: Debug> {}
In here, if you call visibility
on T
, it’ll panic.
sourcepub fn inhabited_predicate_adt(
self,
key: impl IntoQueryParam<DefId>
) -> inhabited_predicate_adt<'tcx>
pub fn inhabited_predicate_adt(
self,
key: impl IntoQueryParam<DefId>
) -> inhabited_predicate_adt<'tcx>
[query description - consider adding a doc-comment!] computing the uninhabited predicate of {:?}
sourcepub fn inhabited_predicate_type(
self,
key: Ty<'tcx>
) -> inhabited_predicate_type<'tcx>
pub fn inhabited_predicate_type(
self,
key: Ty<'tcx>
) -> inhabited_predicate_type<'tcx>
Do not call this query directly: invoke Ty::inhabited_predicate
instead.
sourcepub fn dep_kind(self, key: CrateNum) -> dep_kind<'tcx>
pub fn dep_kind(self, key: CrateNum) -> dep_kind<'tcx>
[query description - consider adding a doc-comment!] fetching what a dependency looks like
sourcepub fn crate_name(self, key: CrateNum) -> crate_name<'tcx>
pub fn crate_name(self, key: CrateNum) -> crate_name<'tcx>
Gets the name of the crate.
sourcepub fn module_children(
self,
key: impl IntoQueryParam<DefId>
) -> module_children<'tcx>
pub fn module_children(
self,
key: impl IntoQueryParam<DefId>
) -> module_children<'tcx>
[query description - consider adding a doc-comment!] collecting child items of module tcx.def_path_str(def_id)
sourcepub fn extern_mod_stmt_cnum(self, key: LocalDefId) -> extern_mod_stmt_cnum<'tcx>
pub fn extern_mod_stmt_cnum(self, key: LocalDefId) -> extern_mod_stmt_cnum<'tcx>
[query description - consider adding a doc-comment!] computing crate imported by tcx.def_path_str(def_id.to_def_id())
sourcepub fn lib_features(self, key: ()) -> lib_features<'tcx>
pub fn lib_features(self, key: ()) -> lib_features<'tcx>
[query description - consider adding a doc-comment!] calculating the lib features map
sourcepub fn defined_lib_features(self, key: CrateNum) -> defined_lib_features<'tcx>
pub fn defined_lib_features(self, key: CrateNum) -> defined_lib_features<'tcx>
[query description - consider adding a doc-comment!] calculating the lib features defined in a crate
sourcepub fn stability_implications(
self,
key: CrateNum
) -> stability_implications<'tcx>
pub fn stability_implications(
self,
key: CrateNum
) -> stability_implications<'tcx>
[query description - consider adding a doc-comment!] calculating the implications between #[unstable]
features defined in a crate
sourcepub fn is_intrinsic(self, key: impl IntoQueryParam<DefId>) -> is_intrinsic<'tcx>
pub fn is_intrinsic(self, key: impl IntoQueryParam<DefId>) -> is_intrinsic<'tcx>
Whether the function is an intrinsic
sourcepub fn get_lang_items(self, key: ()) -> get_lang_items<'tcx>
pub fn get_lang_items(self, key: ()) -> get_lang_items<'tcx>
Returns the lang items defined in another crate by loading it from metadata.
sourcepub fn all_diagnostic_items(self, key: ()) -> all_diagnostic_items<'tcx>
pub fn all_diagnostic_items(self, key: ()) -> all_diagnostic_items<'tcx>
Returns all diagnostic items defined in all crates.
sourcepub fn defined_lang_items(self, key: CrateNum) -> defined_lang_items<'tcx>
pub fn defined_lang_items(self, key: CrateNum) -> defined_lang_items<'tcx>
Returns the lang items defined in another crate by loading it from metadata.
sourcepub fn diagnostic_items(self, key: CrateNum) -> diagnostic_items<'tcx>
pub fn diagnostic_items(self, key: CrateNum) -> diagnostic_items<'tcx>
Returns the diagnostic items defined in a crate.
sourcepub fn missing_lang_items(self, key: CrateNum) -> missing_lang_items<'tcx>
pub fn missing_lang_items(self, key: CrateNum) -> missing_lang_items<'tcx>
[query description - consider adding a doc-comment!] calculating the missing lang items in a crate
sourcepub fn visible_parent_map(self, key: ()) -> visible_parent_map<'tcx>
pub fn visible_parent_map(self, key: ()) -> visible_parent_map<'tcx>
[query description - consider adding a doc-comment!] calculating the visible parent map
sourcepub fn trimmed_def_paths(self, key: ()) -> trimmed_def_paths<'tcx>
pub fn trimmed_def_paths(self, key: ()) -> trimmed_def_paths<'tcx>
[query description - consider adding a doc-comment!] calculating trimmed def paths
sourcepub fn missing_extern_crate_item(
self,
key: CrateNum
) -> missing_extern_crate_item<'tcx>
pub fn missing_extern_crate_item(
self,
key: CrateNum
) -> missing_extern_crate_item<'tcx>
[query description - consider adding a doc-comment!] seeing if we’re missing an extern crate
item for this crate
sourcepub fn used_crate_source(self, key: CrateNum) -> used_crate_source<'tcx>
pub fn used_crate_source(self, key: CrateNum) -> used_crate_source<'tcx>
[query description - consider adding a doc-comment!] looking at the source for a crate
sourcepub fn debugger_visualizers(self, key: CrateNum) -> debugger_visualizers<'tcx>
pub fn debugger_visualizers(self, key: CrateNum) -> debugger_visualizers<'tcx>
Returns the debugger visualizers defined for this crate.
sourcepub fn postorder_cnums(self, key: ()) -> postorder_cnums<'tcx>
pub fn postorder_cnums(self, key: ()) -> postorder_cnums<'tcx>
[query description - consider adding a doc-comment!] generating a postorder list of CrateNums
sourcepub fn is_private_dep(self, key: CrateNum) -> is_private_dep<'tcx>
pub fn is_private_dep(self, key: CrateNum) -> is_private_dep<'tcx>
Returns whether or not the crate with CrateNum ‘cnum’ is marked as a private dependency
sourcepub fn allocator_kind(self, key: ()) -> allocator_kind<'tcx>
pub fn allocator_kind(self, key: ()) -> allocator_kind<'tcx>
[query description - consider adding a doc-comment!] getting the allocator kind for the current crate
sourcepub fn alloc_error_handler_kind(self, key: ()) -> alloc_error_handler_kind<'tcx>
pub fn alloc_error_handler_kind(self, key: ()) -> alloc_error_handler_kind<'tcx>
[query description - consider adding a doc-comment!] alloc error handler kind for the current crate
sourcepub fn upvars_mentioned(
self,
key: impl IntoQueryParam<DefId>
) -> upvars_mentioned<'tcx>
pub fn upvars_mentioned(
self,
key: impl IntoQueryParam<DefId>
) -> upvars_mentioned<'tcx>
[query description - consider adding a doc-comment!] collecting upvars mentioned in tcx.def_path_str(def_id)
sourcepub fn maybe_unused_trait_imports(
self,
key: ()
) -> maybe_unused_trait_imports<'tcx>
pub fn maybe_unused_trait_imports(
self,
key: ()
) -> maybe_unused_trait_imports<'tcx>
[query description - consider adding a doc-comment!] fetching potentially unused trait imports
sourcepub fn maybe_unused_extern_crates(
self,
key: ()
) -> maybe_unused_extern_crates<'tcx>
pub fn maybe_unused_extern_crates(
self,
key: ()
) -> maybe_unused_extern_crates<'tcx>
[query description - consider adding a doc-comment!] looking up all possibly unused extern crates
sourcepub fn names_imported_by_glob_use(
self,
key: LocalDefId
) -> names_imported_by_glob_use<'tcx>
pub fn names_imported_by_glob_use(
self,
key: LocalDefId
) -> names_imported_by_glob_use<'tcx>
[query description - consider adding a doc-comment!] finding names imported by glob use for tcx.def_path_str(def_id.to_def_id())
sourcepub fn stability_index(self, key: ()) -> stability_index<'tcx>
pub fn stability_index(self, key: ()) -> stability_index<'tcx>
[query description - consider adding a doc-comment!] calculating the stability index for the local crate
sourcepub fn crates(self, key: ()) -> crates<'tcx>
pub fn crates(self, key: ()) -> crates<'tcx>
[query description - consider adding a doc-comment!] fetching all foreign CrateNum instances
sourcepub fn traits_in_crate(self, key: CrateNum) -> traits_in_crate<'tcx>
pub fn traits_in_crate(self, key: CrateNum) -> traits_in_crate<'tcx>
A list of all traits in a crate, used by rustdoc and error reporting.
NOTE: Not named just traits
due to a naming conflict.
sourcepub fn exported_symbols(self, key: CrateNum) -> exported_symbols<'tcx>
pub fn exported_symbols(self, key: CrateNum) -> exported_symbols<'tcx>
The list of symbols exported from the given crate.
- All names contained in
exported_symbols(cnum)
are guaranteed to correspond to a publicly visible symbol incnum
machine code. - The
exported_symbols
sets of different crates do not intersect.
sourcepub fn collect_and_partition_mono_items(
self,
key: ()
) -> collect_and_partition_mono_items<'tcx>
pub fn collect_and_partition_mono_items(
self,
key: ()
) -> collect_and_partition_mono_items<'tcx>
[query description - consider adding a doc-comment!] collect_and_partition_mono_items
sourcepub fn is_codegened_item(
self,
key: impl IntoQueryParam<DefId>
) -> is_codegened_item<'tcx>
pub fn is_codegened_item(
self,
key: impl IntoQueryParam<DefId>
) -> is_codegened_item<'tcx>
[query description - consider adding a doc-comment!] determining whether tcx.def_path_str(def_id)
needs codegen
sourcepub fn codegened_and_inlined_items(
self,
key: ()
) -> codegened_and_inlined_items<'tcx>
pub fn codegened_and_inlined_items(
self,
key: ()
) -> codegened_and_inlined_items<'tcx>
All items participating in code generation together with items inlined into them.
sourcepub fn codegen_unit(self, key: Symbol) -> codegen_unit<'tcx>
pub fn codegen_unit(self, key: Symbol) -> codegen_unit<'tcx>
[query description - consider adding a doc-comment!] getting codegen unit {sym}
sourcepub fn unused_generic_params(
self,
key: InstanceDef<'tcx>
) -> unused_generic_params<'tcx>
pub fn unused_generic_params(
self,
key: InstanceDef<'tcx>
) -> unused_generic_params<'tcx>
[query description - consider adding a doc-comment!] determining which generic parameters are unused by tcx.def_path_str(key.def_id())
sourcepub fn backend_optimization_level(
self,
key: ()
) -> backend_optimization_level<'tcx>
pub fn backend_optimization_level(
self,
key: ()
) -> backend_optimization_level<'tcx>
[query description - consider adding a doc-comment!] optimization level used by backend
sourcepub fn output_filenames(self, key: ()) -> output_filenames<'tcx>
pub fn output_filenames(self, key: ()) -> output_filenames<'tcx>
Return the filenames where output artefacts shall be stored.
This query returns an &Arc
because codegen backends need the value even after the TyCtxt
has been destroyed.
sourcepub fn normalize_projection_ty(
self,
key: CanonicalProjectionGoal<'tcx>
) -> normalize_projection_ty<'tcx>
pub fn normalize_projection_ty(
self,
key: CanonicalProjectionGoal<'tcx>
) -> normalize_projection_ty<'tcx>
Do not call this query directly: invoke normalize
instead.
sourcepub fn try_normalize_generic_arg_after_erasing_regions(
self,
key: ParamEnvAnd<'tcx, GenericArg<'tcx>>
) -> try_normalize_generic_arg_after_erasing_regions<'tcx>
pub fn try_normalize_generic_arg_after_erasing_regions(
self,
key: ParamEnvAnd<'tcx, GenericArg<'tcx>>
) -> try_normalize_generic_arg_after_erasing_regions<'tcx>
Do not call this query directly: invoke try_normalize_erasing_regions
instead.
sourcepub fn implied_outlives_bounds(
self,
key: CanonicalTyGoal<'tcx>
) -> implied_outlives_bounds<'tcx>
pub fn implied_outlives_bounds(
self,
key: CanonicalTyGoal<'tcx>
) -> implied_outlives_bounds<'tcx>
[query description - consider adding a doc-comment!] computing implied outlives bounds for goal.value.value
sourcepub fn dropck_outlives(self, key: CanonicalTyGoal<'tcx>) -> dropck_outlives<'tcx>
pub fn dropck_outlives(self, key: CanonicalTyGoal<'tcx>) -> dropck_outlives<'tcx>
Do not call this query directly:
invoke DropckOutlives::new(dropped_ty)).fully_perform(typeck.infcx)
instead.
sourcepub fn evaluate_obligation(
self,
key: CanonicalPredicateGoal<'tcx>
) -> evaluate_obligation<'tcx>
pub fn evaluate_obligation(
self,
key: CanonicalPredicateGoal<'tcx>
) -> evaluate_obligation<'tcx>
Do not call this query directly: invoke infcx.predicate_may_hold()
or
infcx.predicate_must_hold()
instead.
sourcepub fn evaluate_goal(
self,
key: CanonicalChalkEnvironmentAndGoal<'tcx>
) -> evaluate_goal<'tcx>
pub fn evaluate_goal(
self,
key: CanonicalChalkEnvironmentAndGoal<'tcx>
) -> evaluate_goal<'tcx>
[query description - consider adding a doc-comment!] evaluating trait selection obligation goal.value
sourcepub fn type_op_ascribe_user_type(
self,
key: CanonicalTypeOpAscribeUserTypeGoal<'tcx>
) -> type_op_ascribe_user_type<'tcx>
pub fn type_op_ascribe_user_type(
self,
key: CanonicalTypeOpAscribeUserTypeGoal<'tcx>
) -> type_op_ascribe_user_type<'tcx>
Do not call this query directly: part of the Eq
type-op
sourcepub fn type_op_eq(self, key: CanonicalTypeOpEqGoal<'tcx>) -> type_op_eq<'tcx>
pub fn type_op_eq(self, key: CanonicalTypeOpEqGoal<'tcx>) -> type_op_eq<'tcx>
Do not call this query directly: part of the Eq
type-op
sourcepub fn type_op_subtype(
self,
key: CanonicalTypeOpSubtypeGoal<'tcx>
) -> type_op_subtype<'tcx>
pub fn type_op_subtype(
self,
key: CanonicalTypeOpSubtypeGoal<'tcx>
) -> type_op_subtype<'tcx>
Do not call this query directly: part of the Subtype
type-op
sourcepub fn type_op_prove_predicate(
self,
key: CanonicalTypeOpProvePredicateGoal<'tcx>
) -> type_op_prove_predicate<'tcx>
pub fn type_op_prove_predicate(
self,
key: CanonicalTypeOpProvePredicateGoal<'tcx>
) -> type_op_prove_predicate<'tcx>
Do not call this query directly: part of the ProvePredicate
type-op
sourcepub fn type_op_normalize_ty(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, Ty<'tcx>>
) -> type_op_normalize_ty<'tcx>
pub fn type_op_normalize_ty(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, Ty<'tcx>>
) -> type_op_normalize_ty<'tcx>
Do not call this query directly: part of the Normalize
type-op
sourcepub fn type_op_normalize_predicate(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, Predicate<'tcx>>
) -> type_op_normalize_predicate<'tcx>
pub fn type_op_normalize_predicate(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, Predicate<'tcx>>
) -> type_op_normalize_predicate<'tcx>
Do not call this query directly: part of the Normalize
type-op
sourcepub fn type_op_normalize_poly_fn_sig(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, PolyFnSig<'tcx>>
) -> type_op_normalize_poly_fn_sig<'tcx>
pub fn type_op_normalize_poly_fn_sig(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, PolyFnSig<'tcx>>
) -> type_op_normalize_poly_fn_sig<'tcx>
Do not call this query directly: part of the Normalize
type-op
sourcepub fn type_op_normalize_fn_sig(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, FnSig<'tcx>>
) -> type_op_normalize_fn_sig<'tcx>
pub fn type_op_normalize_fn_sig(
self,
key: CanonicalTypeOpNormalizeGoal<'tcx, FnSig<'tcx>>
) -> type_op_normalize_fn_sig<'tcx>
Do not call this query directly: part of the Normalize
type-op
sourcepub fn subst_and_check_impossible_predicates(
self,
key: (DefId, SubstsRef<'tcx>)
) -> subst_and_check_impossible_predicates<'tcx>
pub fn subst_and_check_impossible_predicates(
self,
key: (DefId, SubstsRef<'tcx>)
) -> subst_and_check_impossible_predicates<'tcx>
[query description - consider adding a doc-comment!] checking impossible substituted predicates: tcx.def_path_str(key.0)
sourcepub fn is_impossible_method(
self,
key: (DefId, DefId)
) -> is_impossible_method<'tcx>
pub fn is_impossible_method(
self,
key: (DefId, DefId)
) -> is_impossible_method<'tcx>
[query description - consider adding a doc-comment!] checking if tcx.def_path_str(key.1)
is impossible to call within tcx.def_path_str(key.0)
sourcepub fn method_autoderef_steps(
self,
key: CanonicalTyGoal<'tcx>
) -> method_autoderef_steps<'tcx>
pub fn method_autoderef_steps(
self,
key: CanonicalTyGoal<'tcx>
) -> method_autoderef_steps<'tcx>
[query description - consider adding a doc-comment!] computing autoderef types for goal.value.value
sourcepub fn supported_target_features(
self,
key: CrateNum
) -> supported_target_features<'tcx>
pub fn supported_target_features(
self,
key: CrateNum
) -> supported_target_features<'tcx>
[query description - consider adding a doc-comment!] looking up supported target features
sourcepub fn instance_def_size_estimate(
self,
key: InstanceDef<'tcx>
) -> instance_def_size_estimate<'tcx>
pub fn instance_def_size_estimate(
self,
key: InstanceDef<'tcx>
) -> instance_def_size_estimate<'tcx>
Get an estimate of the size of an InstanceDef based on its MIR for CGU partitioning.
sourcepub fn features_query(self, key: ()) -> features_query<'tcx>
pub fn features_query(self, key: ()) -> features_query<'tcx>
[query description - consider adding a doc-comment!] looking up enabled feature gates
sourcepub fn resolve_instance(
self,
key: ParamEnvAnd<'tcx, (DefId, SubstsRef<'tcx>)>
) -> resolve_instance<'tcx>
pub fn resolve_instance(
self,
key: ParamEnvAnd<'tcx, (DefId, SubstsRef<'tcx>)>
) -> resolve_instance<'tcx>
Attempt to resolve the given DefId
to an Instance
, for the
given generics args (SubstsRef
), returning one of:
Ok(Some(instance))
on successOk(None)
when theSubstsRef
are still too generic, and therefore don’t allow finding the finalInstance
Err(ErrorGuaranteed)
when theInstance
resolution process couldn’t complete due to errors elsewhere - this is distinct fromOk(None)
to avoid misleading diagnostics when an error has already been/will be emitted, for the original cause
sourcepub fn resolve_instance_of_const_arg(
self,
key: ParamEnvAnd<'tcx, (LocalDefId, DefId, SubstsRef<'tcx>)>
) -> resolve_instance_of_const_arg<'tcx>
pub fn resolve_instance_of_const_arg(
self,
key: ParamEnvAnd<'tcx, (LocalDefId, DefId, SubstsRef<'tcx>)>
) -> resolve_instance_of_const_arg<'tcx>
[query description - consider adding a doc-comment!] resolving instance of the const argument ty :: Instance :: new(key.value.0.to_def_id(), key.value.2)
sourcepub fn reveal_opaque_types_in_bounds(
self,
key: &'tcx List<Predicate<'tcx>>
) -> reveal_opaque_types_in_bounds<'tcx>
pub fn reveal_opaque_types_in_bounds(
self,
key: &'tcx List<Predicate<'tcx>>
) -> reveal_opaque_types_in_bounds<'tcx>
[query description - consider adding a doc-comment!] revealing opaque types in {:?}
sourcepub fn limits(self, key: ()) -> limits<'tcx>
pub fn limits(self, key: ()) -> limits<'tcx>
[query description - consider adding a doc-comment!] looking up limits
sourcepub fn diagnostic_hir_wf_check(
self,
key: (Predicate<'tcx>, WellFormedLoc)
) -> diagnostic_hir_wf_check<'tcx>
pub fn diagnostic_hir_wf_check(
self,
key: (Predicate<'tcx>, WellFormedLoc)
) -> diagnostic_hir_wf_check<'tcx>
Performs an HIR-based well-formed check on the item with the given HirId
. If
we get an Unimplemented
error that matches the provided Predicate
, return
the cause of the newly created obligation.
This is only used by error-reporting code to get a better cause (in particular, a better
span) for an existing error. Therefore, it is best-effort, and may never handle
all of the cases that the normal ty::Ty
-based wfcheck does. This is fine,
because the ty::Ty
-based wfcheck is always run.
sourcepub fn global_backend_features(self, key: ()) -> global_backend_features<'tcx>
pub fn global_backend_features(self, key: ()) -> global_backend_features<'tcx>
The list of backend features computed from CLI flags (-Ctarget-cpu
, -Ctarget-feature
,
--target
and similar).
sourcepub fn generator_diagnostic_data(
self,
key: impl IntoQueryParam<DefId>
) -> generator_diagnostic_data<'tcx>
pub fn generator_diagnostic_data(
self,
key: impl IntoQueryParam<DefId>
) -> generator_diagnostic_data<'tcx>
[query description - consider adding a doc-comment!] looking up generator diagnostic data of tcx.def_path_str(key)
sourcepub fn permits_uninit_init(
self,
key: TyAndLayout<'tcx>
) -> permits_uninit_init<'tcx>
pub fn permits_uninit_init(
self,
key: TyAndLayout<'tcx>
) -> permits_uninit_init<'tcx>
[query description - consider adding a doc-comment!] checking to see if key.ty
permits being left uninit
sourcepub fn permits_zero_init(self, key: TyAndLayout<'tcx>) -> permits_zero_init<'tcx>
pub fn permits_zero_init(self, key: TyAndLayout<'tcx>) -> permits_zero_init<'tcx>
[query description - consider adding a doc-comment!] checking to see if key.ty
permits being left zeroed
sourcepub fn compare_assoc_const_impl_item_with_trait_item(
self,
key: (LocalDefId, DefId)
) -> compare_assoc_const_impl_item_with_trait_item<'tcx>
pub fn compare_assoc_const_impl_item_with_trait_item(
self,
key: (LocalDefId, DefId)
) -> compare_assoc_const_impl_item_with_trait_item<'tcx>
[query description - consider adding a doc-comment!] checking assoc const tcx.def_path_str(key.0.to_def_id())
has the same type as trait item
sourcepub fn deduced_param_attrs(
self,
key: impl IntoQueryParam<DefId>
) -> deduced_param_attrs<'tcx>
pub fn deduced_param_attrs(
self,
key: impl IntoQueryParam<DefId>
) -> deduced_param_attrs<'tcx>
[query description - consider adding a doc-comment!] deducing parameter attributes for tcx.def_path_str(def_id)
source§impl<'tcx> TyCtxtAt<'tcx>
impl<'tcx> TyCtxtAt<'tcx>
pub fn def_kind(self, def_id: impl IntoQueryParam<DefId>) -> DefKind
source§impl<'tcx> TyCtxtAt<'tcx>
impl<'tcx> TyCtxtAt<'tcx>
sourcepub fn create_def(
self,
parent: LocalDefId,
data: DefPathData
) -> TyCtxtFeed<'tcx, LocalDefId>
pub fn create_def(
self,
parent: LocalDefId,
data: DefPathData
) -> TyCtxtFeed<'tcx, LocalDefId>
Create a new definition within the incr. comp. engine.
source§impl<'tcx> TyCtxtAt<'tcx>
impl<'tcx> TyCtxtAt<'tcx>
sourcepub fn ty_error(self) -> Ty<'tcx>
pub fn ty_error(self) -> Ty<'tcx>
Constructs a TyKind::Error
type and registers a delay_span_bug
to ensure it gets used.
sourcepub fn ty_error_with_message(self, msg: &str) -> Ty<'tcx>
pub fn ty_error_with_message(self, msg: &str) -> Ty<'tcx>
Constructs a TyKind::Error
type and registers a delay_span_bug
with the given `msg to
ensure it gets used.
pub fn mk_trait_ref(
self,
trait_lang_item: LangItem,
substs: impl IntoIterator<Item = impl Into<GenericArg<'tcx>>>
) -> TraitRef<'tcx>
Methods from Deref<Target = TyCtxt<'tcx>>§
pub const COMMON_VTABLE_ENTRIES: &'tcx [VtblEntry<'tcx>] = _
pub const BOOL_TY_FOR_UNIT_TESTING: Ty<'tcx> = _
Trait Implementations§
source§impl<'tcx> HasDataLayout for TyCtxtAt<'tcx>
impl<'tcx> HasDataLayout for TyCtxtAt<'tcx>
fn data_layout(&self) -> &TargetDataLayout
source§impl<'tcx> HasTargetSpec for TyCtxtAt<'tcx>
impl<'tcx> HasTargetSpec for TyCtxtAt<'tcx>
fn target_spec(&self) -> &Target
impl<'tcx> Copy for TyCtxtAt<'tcx>
Auto Trait Implementations§
impl<'tcx> !RefUnwindSafe for TyCtxtAt<'tcx>
impl<'tcx> !Send for TyCtxtAt<'tcx>
impl<'tcx> !Sync for TyCtxtAt<'tcx>
impl<'tcx> Unpin for TyCtxtAt<'tcx>
impl<'tcx> !UnwindSafe for TyCtxtAt<'tcx>
Blanket Implementations§
source§impl<'tcx, T> ArenaAllocatable<'tcx, IsCopy> for Twhere
T: Copy,
impl<'tcx, T> ArenaAllocatable<'tcx, IsCopy> for Twhere
T: Copy,
fn allocate_on<'a>(self, arena: &'a Arena<'tcx>) -> &'a mut T
fn allocate_from_iter<'a>(
arena: &'a Arena<'tcx>,
iter: impl IntoIterator<Item = T>
) -> &'a mut [T] ⓘ
source§impl<T, R> InternIteratorElement<T, R> for T
impl<T, R> InternIteratorElement<T, R> for T
type Output = R
fn intern_with<I, F>(iter: I, f: F) -> <T as InternIteratorElement<T, R>>::Outputwhere
I: Iterator<Item = T>,
F: FnOnce(&[T]) -> R,
source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
source§impl<'tcx, T> ToPredicate<'tcx, T> for T
impl<'tcx, T> ToPredicate<'tcx, T> for T
fn to_predicate(self, _tcx: TyCtxt<'tcx>) -> T
source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error(tcx: Tcx, _: &[QueryInfo]) -> T
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference’s “Type Layout” chapter for details on type layout guarantees.
Size: 16 bytes